如何用C++实现选择排序算法的具体代码示例?
时间: 2024-10-22 10:26:28 浏览: 22
选择排序是一种简单直观的排序算法,它的工作原理是在未排序序列中找到最小(或最大)元素,存放到排序序列的起始位置,然后再从剩余未排序元素中继续寻找最小元素,直到所有元素均排序完毕。以下是C++实现选择排序的一个例子:
```cpp
#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;
}
}
// 将找到的最小元素交换到已排序部分的开头
std::swap(arr[i], arr[minIndex]);
}
}
// 示例
int main() {
int data[] = {5, 2, 4, 6, 1, 3};
int size = sizeof(data) / sizeof(data[0]);
std::cout << "Original array:\n";
for (int i = 0; i < size; ++i) {
std::cout << data[i] << " ";
}
selectionSort(data, size);
std::cout << "\nSorted array after Selection Sort:\n";
for (int i = 0; i < size; ++i) {
std::cout << data[i] << " ";
}
return 0;
}
```
在这个例子中,`selectionSort`函数接收一个整数数组和它的大小,然后通过两个嵌套循环分别找到当前未排序部分的最小值,并将其放置在已排序部分的开始。`main`函数展示了如何创建一个数组并应用选择排序。
阅读全文