일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- 방송통신대학교
- EOI
- 방통대
- 코딩테스트
- zeros
- 마니토바
- C++
- LV1
- 머신러닝
- MATLAB
- cpp
- 개발자
- leetcode
- mpnp
- 캐나다 영주권
- 기본
- 알고리즘
- omscs
- 온라인석사
- Deep learning
- 컴퓨터과학과
- 선형대수
- 조지아텍
- 매트랩
- 딥러닝
- 주정부이민
- machine learning
- 프로그래머스
- LAA
- Plotting
Archives
- Today
- Total
Byte by Byte
quick sort (C++) 본문
#include <iostream>
using namespace std;
int partition(int arr[], int low, int high){
int pivot = arr[high];
int i = low - 1;
for (int j = low; j < high; j++){
if (arr[j] < pivot){
i++;
swap(arr[i], arr[j]);
}
}
swap(arr[i + 1], arr[high]);
return (i + 1);
}
void quick_sort(int arr[], int low, int high){
if (low < high) {
//pi = pivotindex
int pi = partition(arr, low, high);
quick_sort(arr, low, pi - 1);
quick_sort(arr, pi + 1, high);
}
}
int main(){
int arr[] = {10, 5, 17, 3, 8, 14, 20, 1, 6, 13, 18, 2, 7, 12, 19, 4, 9, 15, 11, 16};
int size = sizeof(arr) / sizeof(arr[0]);
int low = 0;
int high = size - 1;
quick_sort(arr, low, high);
for (int i = 0; i < size; i++)
cout << arr[i] << ' ';
return 0;
}
'개발 로그 > 자료구조' 카테고리의 다른 글
binary search (C++) (0) | 2024.02.09 |
---|---|
bfs graph (C++) (0) | 2024.02.09 |