C++中的选择排序是一种简单直观的排序算法,它的基本思想是每次从待排序的数据元素中选出最小(或最大)的一个元素,顺序放在已排好序的数列的最后,直到全部待排序的数据元素排完为止。下面是一个简单的C++选择排序的示例代码:
#include <iostream>
void selectionSort(int arr[], int n) {
for (int i = 0; i < n - 1; i++) {
int minIndex = i;
for (int j = i + 1; j < n; j++) {
if (arr[j] < arr[minIndex]) {
minIndex = j;
}
}
// Swap the found minimum element with the first element
int temp = arr[minIndex];
arr[minIndex] = arr[i];
arr[i] = temp;
}
}
void printArray(int arr[], int size) {
for (int i = 0; i < size; i++) {
std::cout << arr[i] << " ";
}
std::cout << std::endl;
}
int main() {
int arr[] = {64, 25, 12, 22, 11};
int n = sizeof(arr) / sizeof(arr[0]);
std::cout << "Original array:" << std::endl;
printArray(arr, n);
selectionSort(arr, n);
std::cout << "Sorted array:" << std::endl;
printArray(arr, n);
return 0;
}
在这个示例中,selectionSort
函数实现了选择排序算法,printArray
函数用于打印数组内容,main
函数中演示了如何使用选择排序对数组进行排序。