c++选择排序算法设计
时间: 2024-09-20 17:12:28 浏览: 27
C++中的选择排序是一种简单直观的排序算法。其基本思想是每一次从待排序的数据元素中选出最小(或最大)的一个元素,存放在序列的起始位置,直到全部待排序的数据元素排完。以下是选择排序的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, 8, 1, 9};
int size = sizeof(data) / sizeof(data[0]);
selectionSort(data, size);
std::cout << "Sorted array: ";
for (int i = 0; i < size; ++i) {
std::cout << data[i] << " ";
}
return 0;
}
```
在这个例子中,`selectionSort`函数接受一个整数数组和它的大小作为输入。内部的两个嵌套循环分别用于查找未排序部分的最小值,并将其放到已排序部分的末尾。