이분 탐색 : 오름차순으로 정렬된 배열을 반복적으로 반으로 나누어 target이 선택될 때까지 탐색하는 알고리즘
- 자료를 오름차순으로 정렬
- 자료의 중간값(mid)이 찾고자 하는 값(target)인지 비교
mid
가target
과 다르다면 대소 관계 비교해 탐색 범위를 좁힌다.target
과mid
가 같을 때까지 아래 조건에 따라 2번과 3번을 반복한다.
(1)target
<mid
일 때end
를mid
왼쪽 값으로 바꿔준다. (절반의 왼쪽 탐색)
(2)target
>mid
일 때start
를mid
오른쪽 값으로 바꿔준다. (절반의 오른쪽 탐색)
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
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)