티스토리 뷰
728x90
반응형
- 이분 탐색이란, 오름차순으로 정렬된 배열을 반복적으로 반으로 나누어 target이 선택될 때까지 탐색하는 알고리즘이다.
1. 이분 탐색의 조건
- 반드시 오름차순으로 정렬된 상태에서 시작해야 한다.
2. 이분 탐색 알고리즘
- 시간복잡도: O(logN)
- 반복문과 재귀 두 가지 방법을 사용할 수 있다.
- 자료를 오름차순으로 정렬한다.
- 자료의 중간값(mid)이 찾고자 하는 값(target)인지 비교한다.
- mid 값이 target과 다르다면 대소관계를 비교하여 탐색 범위를 좁히고, target과 mid 값이 같을 때까지 아래 조건에 따라 2번과 3번을 반복한다.
ⓐ target이 mid 값 보다 작으면 end를 mid 왼쪽 값으로 바꿔준다. (절반의 왼쪽 탐색)
ⓑ target이 mid 값 보다 크면 start를 mid 오른쪽 값으로 바꿔준다. (절반의 오른쪽 탐색)
3. 이분 탐색 함수 (반복문)
def binary_search(target, data):
data.sort()
start = 0 # 맨 처음 위치
end = len(data) - 1 # 맨 마지막 위치
while start <= end:
mid = (start + end) // 2 # 중간값
if data[mid] == target:
return mid # target 위치 반환
elif data[mid] > target: # target이 작으면 왼쪽을 더 탐색
end = mid - 1
else: # target이 크면 오른쪽을 더 탐색
start = mid + 1
return
4. 이분 탐색 함수 (재귀)
def binary_search(target, start, end):
if start > end: # 범위를 넘어도 못찾는다면 -1을 반환
return -1
mid = (start + end) // 2 # 중간값
if data[mid] == target: # 중간값의 데이터가 target과 같다면 mid를 반환
return mid
elif data[mid] > target: # target이 작으면 왼쪽 탐색
end = mid - 1
else: # target이 크면 오른쪽 탐색
start = mid + 1
return binary_search(target, start, end) # 줄어든 범위를 더 탐색
def solution(target, data):
data.sort() # 정렬(필수)
start = 0
end = len(data) - 1
return binary_search(target, start, end)
728x90
반응형
'Study > Algorithm' 카테고리의 다른 글
[알고리즘 / Python] 분리집합 (Disjoint Set / 서로소 집합) (0) | 2023.03.17 |
---|---|
[알고리즘 / Python] 누적합 (Prefix Sum) (0) | 2023.02.13 |
[알고리즘] 이분 그래프 (Bipartite Graph) (0) | 2023.02.09 |
[알고리즘] 동적프로그래밍 (DP, Dynamic Programming) (0) | 2023.01.20 |
[알고리즘 / Python] 가장 긴 증가하는 부분 수열 (LIS) (0) | 2023.01.16 |
댓글
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
TAG
- 1202
- 이분 그래프
- 백준
- 우선순위큐
- 코딩테스트실력진단
- padding mask
- Algorithm
- 파이썬
- greedy
- Look-ahead Mask
- Prefix sum
- 알고리즘
- 구현
- bipartite graph
- dfs
- 누적합
- 그리디
- 수학
- boj
- 이분탐색
- lis
- 코드트리
- COLAB
- pytorch
- DP
- Transformer
- 분리집합
- disjoint set
- 트랜스포머
- python
링크