输入八个数冒泡排序C语言
时间: 2023-06-28 08:16:09 浏览: 120
好的,以下是输入八个数并进行冒泡排序的C语言代码:
```c
#include <stdio.h>
int main() {
int arr[8];
int i, j, temp;
printf("请输入8个整数:\n");
for(i = 0; i < 8; i++) {
scanf("%d", &arr[i]);
}
// 冒泡排序
for(i = 0; i < 7; i++) {
for(j = 0; j < 7-i; 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 < 8; i++) {
printf("%d ", arr[i]);
}
return 0;
}
```
在这份代码中,我们首先定义了一个包含8个元素的整型数组 `arr`,并使用 `for` 循环遍历数组,读入用户输入的8个整数。
接着,我们使用两个 `for` 循环来执行冒泡排序。外层循环控制比较的轮数,内层循环控制每轮比较的次数。每次比较都会判断相邻的两个元素的大小关系,如果前一个元素比后一个元素大,则交换它们的位置。
最后,我们使用另一个 `for` 循环输出排序后的结果。
相关问题
冒泡排序c语言自己输入
冒泡排序是一种简单的排序算法,它通过重复地遍历要排序的数列,一次比较两个元素,如果它们的顺序错误就把它们交换过来。遍历数列的工作是重复进行的,直到没有再需要交换,也就是说该数列已经排序完成。
以下是一个使用C语言实现的冒泡排序程序,用户可以自己输入数列:
```c
#include <stdio.h>
// 冒泡排序函数
void bubbleSort(int arr[], int n) {
int i, j, temp;
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;
}
}
}
}
int main() {
int n, i;
printf("请输入要排序的数字个数: ");
scanf("%d", &n);
int arr[n];
printf("请输入 %d 个数字: ", n);
for (i = 0; i < n; i++) {
scanf("%d", &arr[i]);
}
bubbleSort(arr, n);
printf("排序后的数组: ");
for (i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
printf("\n");
return 0;
}
```
这个程序首先提示用户输入要排序的数字个数,然后用户输入这些数字。接着,程序调用`bubbleSort`函数对数组进行排序,最后输出排序后的数组。
c语言输入十个数冒泡排序
c语言输入十个数并进行冒泡排序的代码如下所示:
```c
#include <stdio.h>
int main() {
int a[10];
int i, j, swap;
printf("请输入十个数:\n");
for (i = 0; i < 10; i++)
scanf("%d", &a[i]);
for (i = 9; i > 0; i--) {
for (j = 0; j < i; j++) {
if (a[j] > a[j+1]) {
swap = a[j];
a[j] = a[j+1];
a[j+1] = swap;
}
}
}
printf("排序后的结果是:\n");
for (i = 0; i < 10; i++)
printf("%d ", a[i]);
return 0;
}
```
阅读全文