알고리즘을 풀면서 문제를 맞추어도 효율이 안좋은 경우가 종종 있다. 시간복잡도를 최대한 줄여 효율을 끌어올려야 겠다고 생각이 들어 시간복잡도를 정리해본다.
삽입(insert,pop), 제거(delete, remove) , 탐색(check ==,≠) 포함여부 확인( catainment(in, not in))의 경우 List는 전부 O(N)이다. Set,Dict은 O(1)혹은 O(len)의 시간을 가지고 있다.
이걸보면 삽입,삭제, 탐색, 포함여부 확인등의 문제는 list보다 set,dict을 사용하는게 효율면에서 뛰어나다고 생각한다.
List
| Operation | Example | Big-O | Notes | 
|---|---|---|---|
| Index | l[i] | O(1) | |
| Store | l[i] = 0 | c2 | r2 | 
| Length | len(l) | c3 | r3 | 
| Append | l.append(5) | O(1) | mostly: ICS-46 covers details | 
| Pop | l.pop() | O(1) | same as l.pop(-1), popping at end | 
| Clear | l.clear() | O(1) | similar to l = [] | 
| Slice | l[a:b] | O(b-a) | l[1:5]:O(l)/l[:]:O(len(l)-0)=O(N) | 
| Extend | l.extend(…) | O(len(…)) | depends only on len of extension | 
| Construction | list(…) | O(len(…)) | depends on length of … iterable | 
| check ==, != | l1 == l2 | O(N) | |
| Insert | l[a:b] = … | O(N) | |
| Delete del | l[i] | O(N) | depends on i; O(N) in worst case | 
| Containment | x in/not in l | O(N) | linearly searches list | 
| Copy | l.copy() | O(N) | Same as l[:] which is O(N) | 
| Remove | l.remove(…) | O(N) | |
| Pop | l.pop(i) | O(N) | O(N-i): l.pop(0):O(N) (see above) | 
| Extreme value | min(l)/max(l) | O(N) | linearly searches list for value | 
| Reverse | l.reverse() | O(N) | |
| Iteration | for v in l: | O(N) | Worst: no return/break in loop | 
| Sort | l.sort() | O(N Log N) | key/reverse mostly doesn’t change | 
| Multiply | k*l | O(k N) | 5l is O(N): len(l)l is O(N**2) | 
Set
| Operation | Example | Big-O | Notes | 
|---|---|---|---|
| Length | len(s) | O(1) | |
| Add | s.add(5) | O(1) | |
| Containment | x in/not in s | O(1) | compare to list/tuple - O(N) | 
| Remove | s.remove(..) | O(1) | compare to list/tuple - O(N) | 
| Discard | s.discard(..) | O(1) | |
| Pop | s.pop() | O(1) | popped value “randomly” selected | 
| Clear | s.clear() | O(1) | similar to s = set() | 
| Construction | set(…) | O(len(…)) | depends on length of … iterable | 
| check ==, != | s != t | O(len(s)) | same as len(t); False in O(1) if the lengths are different | 
| \<=/< | s <= t | O(len(s)) | issubset | 
| />=/> | s >= t | O(len(t)) | issuperset s <= t == t >= s | 
| Union | s t | O(len(s)+len(t)) | |
| Intersection | s & t | O(len(s)+len(t)) | |
| Difference | s - t | O(len(s)+len(t)) | |
| Symmetric Diff | s ^ t | O(len(s)+len(t)) | |
| Iteration | for v in s: | O(N) | Worst: no return/break in loop | 
| Copy | s.copy() | O(N) | 
Dict
| Operation | Example | Big-O | Notes | 
|---|---|---|---|
| Index | d[k] | O(1) | |
| Store | d[k] = v | O(1) | |
| Length | len(d) | O(1) | |
| Delete | del d[k] | O(1) | |
| get/setdefault | d.get(k) | O(1) | |
| Pop | d.pop(k) | O(1) | |
| Pop item | d.popitem() | O(1) | popped item “randomly” selected | 
| Clear | d.clear() | O(1) | similar to s = {} or = dict() | 
| View | d.keys() | O(1) | same for d.values() | 
| Construction | dict(…) | O(len(…)) | depends # (key,value) 2-tuples | 
| Iteration | for k in d: | O(N) | all forms: keys, values, items |