티스토리 뷰
arr = [5, 4, 6, 8, 2, 3, 1, 7, 9, 0]
위 배열을 퀵 정렬을 통해 오름차순으로 정렬해보자.
퀵 정렬은 pivot과 2개의 비교가 필요하다.
arr[0]=5를 pivot으로 설정하고 arr[1]=4부터 뒷방향으로의 비교, arr[9]=0부터 앞방향으로의 비교.
arr[1]의 비교를 i라고 하고, arr[9]의 비교를 j라고 하겠다.
pivot과 i,j를 비교하면 된다.
i는 pivot보다 작을 경우 앞으로 나가고, j는 pivot보다 클 경우 뒤로 간다.
i=arr[1]=4 < arr[0]=5 이므로 i=arr[2]=6이 되고,
j=arr[9]=0 <arr[0]=5 이므로 뒤로가지 않고 정지.
다시 i와 pivot을 비교, i=arr[2]=6 > arr[0]=5 이므로 정지.
i와j가 모두 정지했을 때 두 값을 swap한다.
arr = [5, 4, 0, 8, 2, 3, 1, 7, 9, 6]
i=arr[2]=0 < arr[0]=5 이므로 i=arr[3]=8이 되고 정지.
j=arr[8]=8 > arr[0]=5 이므로 뒤로 가 j=arr[7]=7 > 5 이므로 j=arr[6]=1 < 5이므로 정지.
8과 1을 swap.
arr = [5, 4, 0, 1, 2, 3, 8, 7, 9, 6]
i=arr[6]=8까지 나가고,
j=arr[6]=8에서 뒤로가 arr[5]=3에 위치.
이 때 i와j가 교차되었다.
교차되었을 때의 j값과 pivot을 swap한다.
arr = [3, 4, 0, 1, 2, 5, 8, 7, 9, 6]
pivot을 기준으로 앞의 배열 [3,4,0,1,2]와 뒷 배열 [8,7,9,6]을 다시 퀵정렬로 정렬한다.
앞의 배열의 pivot은 3이다.
i=arr1[1]=4에서 멈춤.
j=arr1[4] = 2에서 멈춤.
swap.
arr1 = [3, 2, 0, 1, 4]
i=arr1[4]=4에서 멈춤.
j=arr1[3]=1에서 멈춤.
교차했으므로 j와 pivot이랑 swap.
i와j는 처음부터 다시 시작한다.
arr1 = [1, 2, 0, 3, 4]
i=arr1[1]=2에서 멈춤.
j=arr1[2]=0에서 멈춤.
둘이 swap.
arr1 = [1, 0, 2, 3, 4]
i=arr1[2]=2에서 멈춤.
j=arr1[1]=0에서 멈춤.
교차했으므로 j와 pivot이랑 swap.
arr1 = [0, 1, 2, 3, 4]
이제 뒷 배열을 보자.
arr2 = [8,7,9,6]
pivot = 8
i=arr2[2]=9에서 멈추고
j=arr2[3]=6에서 멈춘다.
둘이 swap.
arr2 = [8, 7, 6, 9]
i=arr2[3]=9에서 멈추고
j=arr2[2]=6에서 멈춘다.
둘이 교차했으므로 pivot과 j를 swap.
arr2 = [6, 7, 8, 9]
이렇게 앞 배열,5,뒷 배열을 합치면
[0,1,2,3,4,5,6,7,8,9]가 된다.
'알고리즘' 카테고리의 다른 글
코테 / 자동차 테스트(python) (0) | 2023.09.04 |
---|---|
합병 정렬 알고리즘 (0) | 2021.10.18 |
삽입 정렬 알고리즘 (0) | 2021.10.18 |
선택 정렬 알고리즘 (0) | 2021.10.18 |
파이썬 괄호짝 찾기 문제 (0) | 2021.09.20 |
- Total
- Today
- Yesterday
- porks
- 차량 네트워크
- Python
- AVTP
- automotive ethernet
- Ethernet
- PCA
- SOME/IP
- 로지스틱회귀
- AE
- json2html
- SVM
- many-to-one
- 이상탐지
- cuckoo
- HTML
- 크로스 엔트로피
- 차량용 이더넷
- 회귀
- problem statement
- 케라스
- 단순선형회귀
- one-to-many
- CAN-FD
- 논문 잘 쓰는법
- many-to-many
- AVB
- 머신러닝
- automotive
- 딥러닝
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |