Home 기본 정렬 알고리즘!
Post
Cancel

기본 정렬 알고리즘!

기본 정렬 알고리즘(버블, 삽입, 선택)

1. 버블 정렬

  • for문을 한 번 돌면 마지막에는 무조건 큰 숫자가 담긴다
  • 기준 인덱스와 바로 뒤 인덱스를 비교하여 앞에가 크면 자리를 바꾼다
  • 이중 for문을 돈다 ( 처음 for은 처음 부터 끝까지 -1, 두번째 for은 총 길이 - 처음for문의 인덱스 -1)
  • 시간 복잡도는 O($n^2$)
  • 정확하게는 $\frac { n * (n - 1)}{ 2 }$
1
2
3
4
5
6
def bubblesort(list_):
    for idx1 in range(len(list_) - 1):
        for idx2 in range(len(list_) - idx1 - 1):
            if list_[idx2] > list_[idx2+1]:
                list_[idx2], list_[idx2+1] = list_[idx2+1], list_[idx2]
    return list_
  • 한 번도 스왑swap이 안 된다면 정렬이 되어있는 상태이므로 끝내줄 수 있다.
1
2
3
4
5
6
7
8
9
10
def bubblesort(list_):
    for idx1 in range(len(list_) - 1):
        swap = False
        for idx2 in range(len(list_) - idx1 - 1):
            if list_[idx2] > list_[idx2+1]:
                list_[idx2], list_[idx2+1] = list_[idx2+1], list_[idx2]
                swap = True
        if swap == False:
            break
    return list_

2. 삽입 정렬

  • 기준과 기준 다음 데이터를 비교하고 기준보다 작으면 기준 역순으로 작을 때마다 자리를 바꿔주며 정렬하는 것
  • 이중 for문을 돈다(처음 for은 len(리스트)-1, 두번째 for은 처음보다 1큰 인덱스에서부터 역순으로 1번째 까지
  • 시간 복잡도는 O($n^2$)
  • 정확하게는 O($n*(n-1)\over2$)$\frac { n * (n - 1)}{ 2 }$
1
2
3
4
5
6
7
8
9
10
#나
def insert_sort(ary):
    for idx1 in range(len(ary)-1):
        if li[idx1] > li[idx1 + 1]:
            for idx2 in range(idx1+1,0,-1):
                if ary[idx2-1] > ary[idx2]:
                    ary[idx2-1], ary[idx2] = ary[idx2], ary[idx2-1]
                else:
                    break
    return ary
1
2
3
4
5
6
7
8
9
#패캠
def insertion_sort(data):
    for index in range(len(data) - 1):
        for index2 in range(index + 1, 0, -1):
            if data[index2] < data[index2 - 1]:
                data[index2], data[index2 - 1] = data[index2 - 1], data[index2]
            else:
                break
    return data
1
2
3
4
5
6
7
8
9
10
#스파르타코클
def insertion_sort(array):
    n = len(array)
    for i in range(1, n):
        for j in range(i):
            if array[i - j - 1] > array[i - j]:
                array[i - j - 1], array[i - j] = array[i - j], array[i - j - 1]
            else:
                break
    return array

3. 선택 정렬

  • 해당 리스트에서 최솟값을 찾아서 현재의 맨 앞과 바꾼다
  • 시간 복잡도는 O($n^2$)
  • 정확하게는 $\frac { n * (n - 1)}{ 2 }$
1
2
3
4
5
6
7
8
9
10
def select_sort(li):
    for idx1 in range(len(li)-1):
        low_idx = idx1
        for idx2 in range(idx1+1, len(li)):
            if li[idx2] < li[low_idx]:
                low_idx = idx2

        li[idx1],li[low_idx] = li[low_idx], li[idx1]
    return li
select_sort([2,3,4,1,6,4,9,2])
This post is licensed under CC BY 4.0 by the author.