CS/Python
[자료구조] 완전탐색/이분탐색
Cori
2021. 9. 3. 20:23
완전탐색
0) 정의
-> 가능한 모든 경우의 수를 다 구해서 값을 찾는 과정으로, 브루트 포스(Brute Force)라고도 불린다.
1) 동작
2) 구현
· 반복문
def solution(trump):
for i in range(len(trump)):
if trump[i] == 7:
return i
return -1 # 7이 없을 경우
· 재귀함수 - 동적 계획법, 백트래킹, 탐욕법 등에 사용됨
def solution(trump, loc):
if trump[loc] == 8:
return loc
else:
return solution(trump, loc + 1)
이분탐색
0) 정의
-> 이진검색이라고도 표현하며, 오름차순으로 정렬된 리스트에서 특정 값의 위치를 찾는 알고리즘이다. 중간의 값을 선택하여 찾고자 하는 값과의 크고 작음을 비교한다.
1) 동작
· index_0의 위치를 left, index_n의 위치를 right, left와 right의 중간 값을 갖는 위치를 mid로 지정
· mid 값과 구하고자 하는 값을 비교
· 기존 mid보다 1이 더 큰 값으로 left를 다시 설정
· 업데이트된 left와 right값을 이용하여 mid를 다시 지정
· 원하는 값을 찾을 때까지 위 과정 반복
2) 구현
def solution(trump):
left = 0
right = len(trump) - 1
while(left <= right):
mid = (left + right) // 2
if trump[mid] == 7:
return mid
elif trump[mid] < 7:
left = mid + 1
elif trump[mid] > 7:
right = mid -1
return mid