Algorithm
배열
isn`t
2024. 9. 1. 10:10
* 파이썬 초정독 스터디 - 코딩테스트 합격자되기 파이썬 편 도서를 참고하여 작성된 글입니다.
배열과 리스트
- 배열 내 데이터에 한 번에 접근할 수 있으니,
위치를 아는 경우
빠르게 탐색할 수 있음. 이와 같은 방식을임의 접근
이라 하며, O(1) - 배열과 리스트는 정확히는 다르지만 파이썬의 리스트는 타 언어의 배열 기능을 그대로 활용하면서 크기도 가변적이며 여러 함수를 제공하므로 편의성이 좋음
- 배열은 요소가 모두 동일한 타입으로 이루어져 있지만, 파이썬의 리스트는 여러 타입의 요소로 구성되어 유연함/효율성에 차이가 있음.
리스트 컴프리헨션
- 리스트 내부에 코드를 작성하는 방법
- for 문의 반복변수는 for문 앞에 표기하고, 리스트에 최종적으로 들어가는 값의 기준이 됨.
- 나머지 모든 표현은 for문 뒤에 표기
ex)numbers = [] for i in range(1,11): numbers.append(i) #[1,2,3,4,5,6,7,8,9,10]
이 코드는 아래와 같이 리스트 컴프리헨션으로 표현할 수 있음
[x for x in range(1,11)] #[1,2,3,4,5,6,7,8,9,10]
만약 조건식을 추가한다면
[2*x for x in range(1,11)] #[2,4,6,8,10,12,14,16,18,20]
홀수인 x만으로 리스트를 만들도록 조건문을 추가한다면
[x for x in range(1,11) if x%2 == 1 ] # [1,3,5,7,9]
반복 변수가 여러개라면
[(x,y) for x in [1,3] for y in [2,4]] #[(1,2),(1,4),(3,2),(3,4)]
반복 변수가 여러 개이면서 조건식이 필요하다면
[(x,y) for x in [1,3] for y in [2,4] if x<2 if y%2==0] #[(1, 2), (1, 4)]
배열의 시간복잡도
- 임의 접근시 O(1)
- 맨 뒤에 삽입 O(1)
- 맨 뒤의 인덱스는 계산이 필요 없으므로 임의접근과 동일
- 맨 앞에 삽입 O(n)
- 맨 앞에 삽입하는 경우 나머지 인덱스에 1칸씩 뒤로 미루는 연산이 발생하므로 총 n회.
- 중간(임의의 위치)에 삽입 O(n)
배열을 선택할 때 고려할 점
- 정확한 위치를 아는 경우가 아니라면 데이터 추가나 삭제에 드는 비용이 큼. 그만큼 인덱스를 이동시켜야 하기 때문.
- 임의 접근으로 특정 데이터에 자주 접근하는 경우에는 효율적임
- 너무 큰 데이터는 배열에 저장하면 연산 속도도 떨어지고 메모리도 많이 소모하게 됨
- 따라서 배열을 사용하기 전에는 할당할 수 있는 메모리 크기를 확인하고, 임의접근이 아닌 중간위치 삽입/삭제가 빈번한지 확인해야 함
자주 사용되는 리스트 기법
- append(item) : 끝에 데이터 추가
- + [item] : 리스트를 덧붙일 수 있음
- insert(index, item) : 특정 인덱스에 데이터 삽입
- pop(index) : 특정 인덱스 삭제
- remove(item) : 인수로 받은 값이 처음 등장하는 인덱스 삭제
- index(item) : 특정 데이터가 처음 등장하는 인덱스 리턴
- sort(), sorted() : 내림차순 데이터 정렬
- count(item) : 특정 데이터가 포함된 홧수