본문 바로가기

이론/자료구조와 실습

Sort) Bubble Sort, Selection Sort, Insertion Sort

728x90
반응형

1. 버블 정렬 (Bubble Sort):  O(n²)

def bubble_sort(arr):
    n = len(arr)
    for i in range(n):
        for j in range(0, n-i-1):
            if arr[j] > arr[j+1]:
                arr[j], arr[j+1] = arr[j+1], arr[j]
    return arr

 

2. 선택 정렬 (Selection Sort): O(n²)

def selection_sort(arr):
    n = len(arr)
    for i in range(n):
        min_idx = i
        for j in range(i+1, n):
            if arr[j] < arr[min_idx]:
                min_idx = j
        arr[i], arr[min_idx] = arr[min_idx], arr[i]
    return arr

 

3. 삽입 정렬 (Insertion Sort): O(n²)

def insertion_sort(arr):
    for i in range(1, len(arr)):
        key = arr[i]
        j = i - 1
        while j >= 0 and key < arr[j]:
            arr[j + 1] = arr[j]
            j -= 1
        arr[j + 1] = key
    return arr
728x90
반응형

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

Sort) Quick Sort, Merge Sort, Heap Sort  (1) 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  (0) 2024.01.03