c++选择排序法输入一个正整数n(1<n≤10),再输入n个整数,将这个数列中的第m项到第k项(k>m)中的各整数从 大到小排序后输出。试编写相应程序。
时间: 2023-06-09 16:08:46 浏览: 86
好的,我明白了。这是一个经典的排序问题,可以使用选择排序算法进行解决。以下是相应的代码示例:
```c
#include <stdio.h>
void swap(int *a, int *b) {
int temp = *a;
*a = *b;
*b = temp;
}
void selectionSort(int arr[], int n) {
int i, j, max_idx;
for (i = 0; i < n-1; i++) {
max_idx = i;
for (j = i+1; j < n; j++) {
if (arr[j] > arr[max_idx])
max_idx = j;
}
swap(&arr[i], &arr[max_idx]);
}
}
int main() {
int n, m, k, i;
scanf("%d", &n);
int arr[n];
for (i = 0; i < n; i++) {
scanf("%d", &arr[i]);
}
scanf("%d %d", &m, &k);
selectionSort(arr+(m-1), k-m+1);
for (i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
printf("\n");
return 0;
}
```
输入格式为:首先输入一个正整数n,代表整数的个数;接下来一行输入n个整数;最后一行输入m和k,代表需要排序的整数范围。输出格式为:排好序后的n个整数。
注意,此代码示例中只考虑了不超过 10 个整数的情况。如果有更大的整数范围,需要进行相应的修改。
阅读全文