4.1.5 输入一个正整数n(1 <n≤10),再输入n个整数,将它们从大到小排序后输出。(利用教材中介绍的选择、冒泡、插入排序中的一个算法完成排序操作)c++
时间: 2024-10-05 11:02:30 浏览: 17
在C++中,我们可以使用选择排序、冒泡排序或插入排序来对一组整数进行降序排列。这里以选择排序为例,因为它比较简单且适用于小型数组:
```cpp
#include <iostream>
using namespace std;
// 选择排序函数,返回数组长度
int selectionSort(int arr[], int n) {
for (int i = 0; i < n - 1; ++i) {
// 找到剩余未排序部分的最大值的索引
int max_idx = i;
for (int j = i + 1; j < n; ++j) {
if (arr[j] > arr[max_idx]) {
max_idx = j;
}
}
// 将找到的最大值与当前位置交换
if (max_idx != i) {
swap(arr[i], arr[max_idx]);
}
}
return n;
}
int main() {
int n;
cout << "请输入一个正整数n(1 < n <= 10): ";
cin >> n;
int arr[n];
cout << "请输入" << n << "个整数: ";
for (int i = 0; i < n; ++i) {
cin >> arr[i];
}
// 对数组进行降序排序
selectionSort(arr, n);
// 输出排序后的数组
cout << "从大到小排序后: ";
for (int i = 0; i < n; ++i) {
cout << arr[i] << " ";
}
cout << endl;
return 0;
}
```
在这个程序中,用户首先输入一个数字`n`,然后输入`n`个整数,选择排序会遍历整个数组,每次找到剩余元素中的最大值,将其放置在当前未排序部分的起始位置。最后,程序会输出排序后的结果。
阅读全文