티스토리 뷰
반응형
이진 탐색(Binary Search) 완전 정복: 원리, 구현, 실전 문제까지
**이진 탐색(Binary Search)**은 알고리즘 학습에서 가장 기본이자 강력한 기법입니다.
데이터가 정렬된 상태라는 전제 하에, 탐색 범위를 절반씩 줄여가며 원하는 값을 찾는 효율적인 방법입니다.
이번 글에서는 이진 탐색의 원리부터 재귀/반복 구현 방식, 탐색 실패 시 인덱스 처리, 실전 문제 적용법까지 모두 정리합니다.
✅ 이진 탐색(Binary Search)이란?
이진 탐색은 정렬된 배열에서 원하는 값을 찾기 위해, 중앙값과 비교하여 탐색 범위를 반으로 줄여나가는 방식입니다.
📌 동작 과정 요약
- 중간 인덱스를 찾는다.
- 중간값과 타겟 값을 비교한다.
- 중간값 == 타겟 → 정답
- 중간값 < 타겟 → 오른쪽 절반 탐색
- 중간값 > 타겟 → 왼쪽 절반 탐색
- 탐색 범위가 사라질 때까지 반복
⏱ 시간 복잡도
- O(log n) — 탐색 범위가 매 단계마다 반으로 줄어듦
🧪 이진 탐색 – 반복문 방식 (Iterative)
반응형
def binary_search(arr, target):
left, right = 0, len(arr) - 1
while left <= right:
mid = (left + right) // 2
if arr[mid] == target:
return mid # 정답 위치 반환
elif arr[mid] < target:
left = mid + 1
else:
right = mid - 1
return -1 # 찾지 못한 경우
arr = [1, 3, 5, 7, 9, 11]
print(binary_search(arr, 7)) # 출력: 3
print(binary_search(arr, 4)) # 출력: -1
🧠 이진 탐색 – 재귀 함수 방식 (Recursive)
def binary_search_recursive(arr, target, left, right):
if left > right:
return -1 # 탐색 실패
mid = (left + right) // 2
if arr[mid] == target:
return mid
elif arr[mid] < target:
return binary_search_recursive(arr, target, mid + 1, right)
else:
return binary_search_recursive(arr, target, left, mid - 1)
print(binary_search_recursive(arr, 11, 0, len(arr) - 1)) # 출력: 5
⚠️ 실전에서 주의할 점
✅ 탐색 실패 시 인덱스를 어떻게 활용할까?
- 보통 -1을 반환하지만, **삽입 가능한 위치(index)**가 필요한 경우도 있음
→ 이진 탐색 응용: bisect 모듈 사용
import bisect
arr = [1, 3, 5, 7]
print(bisect.bisect_left(arr, 4)) # 출력: 2 (4를 넣을 위치)
print(bisect.bisect_right(arr, 4)) # 출력: 2
🚀 실전 문제 예제: 숫자 존재 여부 판별
❓ 문제
정렬된 수열에서 특정 수 x가 존재하는지 이진 탐색으로 판별하라.
✅ 코드
def exists(arr, x):
return binary_search(arr, x) != -1
print(exists([2, 4, 6, 8, 10], 8)) # True
print(exists([2, 4, 6, 8, 10], 7)) # False
🔄 응용 패턴: Lower Bound / Upper Bound
- Lower Bound: target 이상이 처음 나오는 위치
- Upper Bound: target 초과가 처음 나오는 위치
import bisect
arr = [1, 2, 4, 4, 4, 5, 7]
print(bisect.bisect_left(arr, 4)) # 출력: 2
print(bisect.bisect_right(arr, 4)) # 출력: 5
→ [4, 4, 4] 구간의 개수는 5 - 2 = 3
🧩 이진 탐색이 쓰이는 실전 문제 유형
문제 유형 설명
값 찾기 | 정렬된 리스트에서 특정 값 탐색 |
개수 세기 | 값의 등장 횟수 (lower/upper bound 사용) |
파라메트릭 서치 | 조건을 만족하는 최소/최대값 찾기 |
최적화 문제 | 조건을 만족하는 가장 작은/큰 수 구하기 |
결정 문제 | "조건 만족 여부" → 이진 탐색으로 판단 |
📌 결론 및 요약
- 이진 탐색은 정렬된 배열에서 **O(log n)**의 속도로 값을 찾을 수 있는 강력한 알고리즘입니다.
- 반복, 재귀, bisect 등 다양한 방식으로 구현 가능하며, 응용 폭도 넓습니다.
- 코딩테스트에서는 탐색 + 조건 검증 패턴으로 자주 출제됩니다.
👉 다음 글에서는 정렬 알고리즘의 종류와 시간복잡도 비교, 그리고 실제 코드 구현을 소개하겠습니다!
📚 참고자료 및 출처
- 『이것이 취업을 위한 코딩 테스트다 with 파이썬』
- Python bisect 모듈 공식 문서: https://docs.python.org/3/library/bisect.html
- GeeksforGeeks – Binary Search
이진탐색, binary search, bisect, 파이썬 알고리즘, 탐색 알고리즘, lower bound, upper bound, 코딩테스트, 시간복잡도, SEO 최적화 10개
'Programming' 카테고리의 다른 글
재귀(Recursion)와 분할정복(Divide & Conquer) 완벽 이해: 원리, 구현, 실전 예제까지 (0) | 2025.04.08 |
---|---|
정렬 알고리즘 총정리: 버블, 선택, 삽입부터 퀵, 병합까지 비교와 구현 (1) | 2025.04.07 |
트리(Tree) 자료구조 쉽게 이해하기: 이진트리부터 탐색까지 한 번에 정리 (0) | 2025.04.02 |
스택(Stack)과 큐(Queue)의 구조, 차이점, 실전 활용법 완전 정리 (1) | 2025.04.01 |
배열 vs 연결리스트 완전 비교: 자료구조 선택 기준과 실제 예제 코드 (1) | 2025.04.01 |
※ 이 포스팅은 쿠팡 파트너스 활동의 일환으로, 이에 따른 일정액의 수수료를 제공받습니다.
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- github
- llm
- rag
- fastapi
- REACT
- Docker
- 프론트엔드
- AI챗봇
- 스마트 컨트랙트
- LangChain
- AI 자동화
- nodejs
- 백엔드개발
- SEO 최적화
- Next.js
- kotlin
- Webpack
- Prisma
- SEO최적화
- Ktor
- gatsbyjs
- PostgreSQL
- App Router
- 웹개발
- NestJS
- nextJS
- CI/CD
- 개발블로그
- 관리자
- seo 최적화 10개
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
글 보관함
반응형