使用c语言的冒泡排序法输入一个正整数n(1<n<11),再输入n个正整数,将他们从大到小排序后输出。
时间: 2024-02-09 16:09:48 浏览: 91
好的,我可以为您提供这样一个C语言程序:
```c
#include <stdio.h>
int main() {
int n, i, j, temp;
int nums[10]; // 假设n不超过10
printf("请输入正整数n(1<n<11):");
scanf("%d", &n);
printf("请输入%d个正整数:", n);
for(i=0; i<n; i++) {
scanf("%d", &nums[i]);
}
// 冒泡排序
for(i=0; i<n-1; i++) {
for(j=0; j<n-1-i; j++) {
if(nums[j] < nums[j+1]) {
temp = nums[j];
nums[j] = nums[j+1];
nums[j+1] = temp;
}
}
}
// 输出排序后的结果
printf("排序后的结果为:");
for(i=0; i<n; i++) {
printf("%d ", nums[i]);
}
return 0;
}
```
请您根据需要自行调整程序中的细节部分。
相关问题
C语言冒泡排序法。输入一个正整数n(1<n<11),在输入n个整数,将他们从大到小排列
好的,以下是C语言实现冒泡排序的代码,可以满足您的要求:
```c
#include <stdio.h>
void bubble_sort(int arr[], int len) {
int i, j, temp;
for (i = 0; i < len - 1; i++) {
for (j = 0; j < len - 1 - i; j++) {
if (arr[j] < arr[j + 1]) {
temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
}
}
}
int main() {
int n, i;
printf("请输入n的值(1<n<11):");
scanf("%d", &n);
int arr[n];
printf("请输入%d个整数:", n);
for (i = 0; i < n; i++) {
scanf("%d", &arr[i]);
}
bubble_sort(arr, n);
printf("从大到小排列后的结果为:");
for (i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
printf("\n");
return 0;
}
```
您可以将以上代码复制到本地的C语言开发环境中运行,输入n和n个整数即可得到排序后的结果。由于您没有透露具体的要求,以上代码可能需要根据实际情况进行修改。
用C语言的形式 编写程序输入一个正整数n(5≤n≤20),再输入n个整数,采用冒泡排序法将这n个整数按照由小到大的顺序输出。
以下是用 C 语言编写的冒泡排序程序:
```c
#include <stdio.h>
int main() {
int n, i, j, temp;
int arr[20];
printf("请输入正整数n(5≤n≤20):");
scanf("%d", &n);
printf("请输入%d个整数:\n", n);
for (i = 0; i < n; i++) {
scanf("%d", &arr[i]);
}
// 冒泡排序
for (i = 0; i < n - 1; i++) {
for (j = 0; j < n - i - 1; j++) {
if (arr[j] > arr[j + 1]) {
temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
}
}
printf("排序后的结果为:\n");
for (i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
printf("\n");
return 0;
}
```
程序先让用户输入正整数 n 和 n 个整数,然后使用冒泡排序法将这 n 个整数按照由小到大的顺序排序,最后输出排序后的结果。
阅读全文
相关推荐














