[c++] 정렬 알고리즘(Sorting Algorithms)
이 블로그 포스트에서는 C++을 사용하여 몇 가지 일반적인 정렬 알고리즘에 대해 살펴보겠습니다. 정렬 알고리즘은 데이터를 순서대로 정렬하는 알고리즘으로, 많은 다양한 상황에서 유용하게 활용됩니다.
버블 정렬
#include <iostream>
using namespace std;
void bubbleSort(int arr[], int n) {
for (int i = 0; i < n-1; i++) {
for (int j = 0; j < n-i-1; j++) {
if (arr[j] > arr[j+1]) {
swap(arr[j], arr[j+1]);
}
}
}
}
int main() {
int arr[] = {64, 34, 25, 12, 22, 11, 90};
int n = sizeof(arr)/sizeof(arr[0]);
bubbleSort(arr, n);
cout << "Sorted array: \n";
for (int i=0; i < n; i++) {
cout << arr[i] << " ";
}
return 0;
}
선택 정렬
#include <iostream>
using namespace std;
void selectionSort(int arr[], int n) {
for (int i = 0; i < n-1; i++) {
int min_idx = i;
for (int j = i+1; j < n; j++) {
if (arr[j] < arr[min_idx]) {
min_idx = j;
}
}
swap(arr[i], arr[min_idx]);
}
}
int main() {
int arr[] = {64, 25, 12, 22, 11};
int n = sizeof(arr)/sizeof(arr[0]);
selectionSort(arr, n);
cout << "Sorted array: \n";
for (int i=0; i < n; i++) {
cout << arr[i] << " ";
}
return 0;
}
삽입 정렬
#include <iostream>
using namespace std;
void insertionSort(int arr[], int n) {
for (int i = 1; i < n; i++) {
int key = arr[i];
int j = i-1;
while (j >= 0 && arr[j] > key) {
arr[j+1] = arr[j];
j--;
}
arr[j+1] = key;
}
}
int main() {
int arr[] = {12, 11, 13, 5, 6};
int n = sizeof(arr)/sizeof(arr[0]);
insertionSort(arr, n);
cout << "Sorted array: \n";
for (int i=0; i < n; i++) {
cout << arr[i] << " ";
}
return 0;
}
퀵 정렬
#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 - 1; j++) {
if (arr[j] < pivot) {
i++;
swap(arr[i], arr[j]);
}
}
swap(arr[i + 1], arr[high]);
return (i + 1);
}
void quickSort(int arr[], int low, int high) {
if (low < high) {
int pi = partition(arr, low, high);
quickSort(arr, low, pi - 1);
quickSort(arr, pi + 1, high);
}
}
int main() {
int arr[] = {10, 7, 8, 9, 1, 5};
int n = sizeof(arr)/sizeof(arr[0]);
quickSort(arr, 0, n-1);
cout << "Sorted array: \n";
for (int i=0; i < n; i++) {
cout << arr[i] << " ";
}
return 0;
}
이러한 정렬 알고리즘들은 개별적인 장단점을 가지고 있으며, 각각의 상황에 맞게 적절한 알고리즘을 선택하는 것이 중요합니다.
더 많은 정보를 원하시면 cppreference를 참고하세요.
이상으로 C++ 정렬 알고리즘에 대한 간단한 소개를 마치겠습니다. 감사합니다!