분할정복은 복잡한 문제를 더 작은 부분 문제(sub-problems)로 나눈 다음, 각 부분 문제를 해결하고 이를 합쳐서 원래의 문제를 해결하는 알고리즘 디자인 패러다임입니다. 분할정복은 주로 재귀적으로 구현됩니다. 대표적인 예로는 퀵 정렬, 병합 정렬, 피보나치 수열 등이 있습니다.
def merge_sort(arr):
if len(arr) <= 1:
return arr
mid = len(arr) // 2
left = arr[:mid]
right = arr[mid:]
left = merge_sort(left)
right = merge_sort(right)
return merge(left, right)
def merge(left, right):
result = []
while left and right:
if left[0] < right[0]:
result.append(left.pop(0))
else:
result.append(right.pop(0))
if left:
result += left
if right:
result += right
return result
arr = [38, 27, 43, 3, 9, 82, 10]
print(merge_sort(arr))
분할정복은 알고리즘 문제 해결 뿐만 아니라 다양한 공학과 학문 분야에서 널리 사용되는 기법입니다. 특히 복잡한 문제를 해결할 때 이 방법론을 적용하면 문제를 더 쉽게 이해하고 풀 수 있습니다.