给定一个数组,需要获取数组进行i趟选择排序后的结果,使用c++完成
时间: 2024-09-30 18:01:38 浏览: 27
LeetCode 每日一题 912. 排序数组 C++描述
5星 · 资源好评率100%
在 C++ 中,选择排序是一种简单直观的排序算法,它的工作原理是每一次从待排序的数据元素中选出最小(或最大)的一个元素,存放在序列的起始位置,直到全部待排序的数据元素排完。以下是使用 C++ 完成 i 趟选择排序并返回每次排序后的数组示例:
```cpp
#include <iostream>
using namespace std;
// 选择排序函数,每趟遍历找出未排序部分的最小值
void selectionSort(int arr[], int n, int i) {
int minIndex = i;
for (int j = i + 1; j < n; ++j) {
if (arr[j] < arr[minIndex]) {
minIndex = j;
}
}
// 将当前趟最小值放到已排序部分的末尾
swap(arr[i], arr[minIndex]);
cout << "After " << i+1 << "th iteration: ";
printArray(arr, n);
}
// 打印数组函数
void printArray(int arr[], int size) {
for (int i = 0; i < size; ++i) {
cout << arr[i] << " ";
}
cout << endl;
}
int main() {
int arr[] = {5, 3, 8, 4, 2}; // 示例数组
int n = sizeof(arr) / sizeof(arr[0]);
int numIterations = 4; // 次数,这里假设你想运行 4 趟
for (int i = 0; i < numIterations; ++i) {
selectionSort(arr, n, i);
}
return 0;
}
```
在这个代码中,`selectionSort` 函数实现了选择排序的核心逻辑,每次遍历时都会找到剩余部分的最小元素,并将它放置到已排序部分的相应位置。`main` 函数则调用了这个排序过程 `numIterations` 次。
阅读全文