일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 스타벅스
- C++
- 알고리즘
- 프로그래머스
- leetcode
- dfs
- 벤쿠버
- 딥러닝
- 모두를 위한 딥러닝
- 다이나믹프로그래밍
- 프로그래밍언어론
- BFS
- 릿코드
- Spring Framework
- 파이썬
- 라인플러스
- jvm
- 시애틀
- 라인
- C/C++
- 백트래킹
- STL
- 스프링 프레임워크
- spring
- binary search
- DP
- 백준
- Java
- Python
- 머신러닝
Archives
- Today
- Total
목록list (1)
케이스윔의 개발 블로그
[C++] STL Container list(리스트)
STL의 여러 컨테이너를 사용해보면서 내부적으로 어떻게 구현이 되어있는지에 대한 고민을 해보지 않았던 것 같다. 그래서 vector를 사용해서 push_back()을 할 때에는 당연히 삽입이므로 시간복잡도가 O(1)일 거라 생각했다. 이번에 한 문제를 풀면서 O(N)이라는 걸 알게 됐다. STL에서 삽입, 삭제에 시간복잡도가 O(1)로 사용할 수 있는 컨테이너는 list다. list는 들어만 보고 vector나 queue를 쓰면 되니까 크게 필요성을 느끼지 못했었다. 그런데 시간복잡도에 대한 고려를 해보면서 시간제한이 있는 문제를 풀 때는 list를 써야된다는 것을 알았다. list 는 시퀀스 컨테이너이고, 노드 기반의 컨테이너이다. (vector와 deque는 배열 기반 컨테이너)따라서 list는 중간..
Study/C&C++
2018. 11. 6. 16:10