본문 바로가기

이론/자료구조와 실습

Sort) Quick Sort, Merge Sort, Heap Sort

728x90
반응형

1. 퀵 정렬 (Quick Sort): O(n log n) ~ O(n²)

def quick_sort(arr):
    if len(arr) <= 1:
        return arr
    pivot = arr[len(arr) // 2]
    left = [x for x in arr if x < pivot]
    middle = [x for x in arr if x == pivot]
    right = [x for x in arr if x > pivot]
    return quick_sort(left) + middle + quick_sort(right)

 

2. 병합 정렬 (Merge Sort): O(n log n)

def merge_sort(arr):
    if len(arr) <= 1:
        return arr

    mid = len(arr) // 2
    left = merge_sort(arr[:mid])
    right = merge_sort(arr[mid:])

    return merge(left, right)

def merge(left, right):
    sorted_arr = []
    i = j = 0

    while i < len(left) and j < len(right):
        if left[i] < right[j]:
            sorted_arr.append(left[i])
            i += 1
        else:
            sorted_arr.append(right[j])
            j += 1

    sorted_arr.extend(left[i:])
    sorted_arr.extend(right[j:])
    return sorted_arr

 

3. 힙 정렬 (Heap Sort): O(n log n)

import heapq

def heap_sort(arr):
    heapq.heapify(arr)  # 리스트를 힙으로 변환
    return [heapq.heappop(arr) for _ in range(len(arr))]
728x90
반응형

'이론 > 자료구조와 실습' 카테고리의 다른 글

Sort) Bubble Sort, Selection Sort, Insertion Sort  (0) 2024.09.29
DP) Dynamic Programming  (0) 2024.01.09
Stack) Stack  (0) 2024.01.05
Queue) Priority Queue  (1) 2024.01.03
Queue) Circular Queue  (1) 2024.01.03