已知数组a[10]={1,3,5,7,9,2,4,6,8,0}。请编写用直接选择法排序的程序,对数组排序后输出到屏幕。
时间: 2023-10-03 22:01:46 浏览: 66
C语言程序设计-编写函数用选择排序法对数组中的数据进行从小到大的排序;
5星 · 资源好评率100%
好的,我可以回答你的问题。下面是使用直接选择法对数组进行排序的程序。
```cpp
#include <iostream>
using namespace std;
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(arr[i], arr[minIndex]);
}
}
int main() {
int a[10] = {1, 3, 5, 7, 9, 2, 4, 6, 8, 0};
int n = 10;
selectionSort(a, n);
for (int i = 0; i < n; i++) {
cout << a[i] << " ";
}
return 0;
}
```
程序的核心部分是 `selectionSort()` 函数,它使用双重循环进行选择排序。外层循环遍历元素,内层循环在未排序的部分中查找最小的元素,并将其与当前元素交换。最后,我们可以打印排序后的数组以验证它是否按正确的顺序排序。
阅读全文