输入一个正整数n (n <=10) ,对一个数组的前n项数据进行从大到小选择排序,其他数据不变。输出排好序的前n个数。#include <stdio.h> int main() { int a[10] = {3,1,2,10,7,8,9,6,5,4}; int n, i, j, k, t; scanf("%d", &n); for(【】) { k = i; for(j=i+1;j < n;j++) { if(【】) k = j; } if(k != i) { t = a[k]; a[k] = a[i]; 【____________】 ; } } for(i = 0; i < n-1; i++) printf("%d ", a[i]); printf("%d\n", a[i]); return 0; }
时间: 2023-12-10 14:03:21 浏览: 82
以下是完整程序,已填上空白处:
```
#include <stdio.h>
int main() {
int a[10] = {3,1,2,10,7,8,9,6,5,4};
int n, i, j, k, t;
scanf("%d", &n);
for(i = 0; i < n-1; i++)
{
k = i;
for(j = i+1; j < n; j++)
{
if(a[j] > a[k]) // 比较符号改为 >
k = j;
}
if(k != i)
{
t = a[k];
a[k] = a[i];
a[i] = t;
}
}
for(i = 0; i < n-1; i++)
printf("%d ", a[i]);
printf("%d\n", a[i]);
return 0;
}
```
这个程序与之前的选择排序程序类似,但是在比较大小时,将比较符号改为了 '>',实现了从大到小排序。同时,由于只需要输出前n个数,所以循环结束条件也改为了 'i < n-1'。
相关问题
输入一个正整数n (n <=10) ,对一个数组的前n项数据进行从大到小选择排序,其他数据不变。输出排好序的前n个数。
好的,以下是 Python 代码实现:
```python
n = int(input("请输入一个正整数n:"))
arr = list(map(int, input("请输入数组元素,以空格分隔:").split()))
# 选择排序
for i in range(n):
max_index = i
for j in range(i+1, n):
if arr[j] > arr[max_index]:
max_index = j
arr[i], arr[max_index] = arr[max_index], arr[i]
# 输出排好序的前n个数
print("排序后的前n个数为:", end="")
for i in range(n):
print(arr[i], end=" ")
```
输入示例:
```
请输入一个正整数n:5
请输入数组元素,以空格分隔:3 6 1 8 2 9 0
```
输出示例:
```
排序后的前n个数为:9 8 6 3 2
```
c语音程序设计:输入一个正整数n (n <=10) ,对一个数组的前n项数据进行从大到小选择排序,其他数据不变。输出排好序的前n个数。
好的,这道题目可以分为两个步骤来实现,第一步是输入数据并进行选择排序,第二步是输出排好序的前n个数。以下是对应的 C 语言代码实现:
```c
#include <stdio.h>
void selection_sort(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;
}
}
int temp = arr[i];
arr[i] = arr[max_idx];
arr[max_idx] = temp;
}
}
int main() {
int n, i;
int arr[10];
printf("请输入一个正整数n (n <=10):\n");
scanf("%d", &n);
printf("请输入%d个整数:\n", n);
for (i = 0; i < n; i++) {
scanf("%d", &arr[i]);
}
selection_sort(arr, n);
printf("排好序的前%d个数为:\n", n);
for (i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
printf("\n");
return 0;
}
```
这段代码中,我们首先定义了一个 `selection_sort` 函数,用于进行选择排序。然后在主函数中,我们首先输入了正整数 `n` 和一个长度为 `n` 的数组 `arr`,然后调用 `selection_sort` 函数对前 `n` 个数进行排序,最后输出排好序的前 `n` 个数。
阅读全文