c语言冒泡法排序数组
时间: 2024-10-02 15:04:49 浏览: 106
冒泡排序是一种简单的排序算法,它重复地遍历待排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。遍历数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。在C语言中,冒泡排序的基本思想可以用以下伪代码表示:
```c
void bubbleSort(int arr[], int n) {
for (int i = 0; i < n - 1; i++) {
for (int j = 0; j < n - i - 1; j++) {
if (arr[j] > arr[j+1]) {
// 交换 arr[j] 和 arr[j+1]
int temp = arr[j];
arr[j] = arr[j+1];
arr[j+1] = temp;
}
}
}
}
```
这个函数接受一个整型数组`arr`和它的长度`n`作为输入,通过两层嵌套循环,外层控制遍历次数,内层则逐次比较并交换相邻未按序排列的元素。
相关问题
C语言使用冒泡法排序数组
当然,以下是使用 C 语言实现冒泡排序的示例代码:
```c
#include <stdio.h>
void bubble_sort(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 arr[] = {64, 34, 25, 12, 22, 11, 90};
int n = sizeof(arr) / sizeof(arr[0]);
int i;
printf("原始数组:\n");
for (i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
bubble_sort(arr, n);
printf("\n排序后的数组:\n");
for (i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
return 0;
}
```
同样,冒泡排序的基本思路是,从第一个元素开始,比较相邻的两个元素,如果第一个元素比第二个元素大,则交换它们的位置。这样一轮下来,最大的元素就被排到了最后面。然后再从第一个元素开始,重复上述过程,直到所有元素都被排好序。
您可以将要排序的数组作为参数传递给该函数,例如:
```c
int arr[] = {64, 34, 25, 12, 22, 11, 90};
int n = sizeof(arr) / sizeof(arr[0]);
bubble_sort(arr, n);
```
输出结果将是原始数组和排好序的数组。
C语言编译一个简单的使用冒泡法排序数组
好的,以下是一个简单的使用冒泡法排序数组的 C 语言程序示例:
```c
#include <stdio.h>
void bubble_sort(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 arr[] = {64, 34, 25, 12, 22, 11, 90};
int n = sizeof(arr) / sizeof(arr[0]);
int i;
printf("原始数组:\n");
for (i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
bubble_sort(arr, n);
printf("\n排序后的数组:\n");
for (i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
return 0;
}
```
在 Windows 系统下,您可以使用任意一种 C 语言编译器来编译和运行该程序,例如 Microsoft Visual Studio、MinGW、Cygwin 等。在 Linux 或 macOS 系统下,您可以使用 GCC 编译器来编译和运行该程序。
假设您使用 GCC 编译器,可以使用以下命令编译和运行程序:
```
gcc -o bubble_sort bubble_sort.c
./bubble_sort
```
其中,`-o` 参数指定编译生成的可执行文件名为 `bubble_sort`,`./bubble_sort` 命令则是运行该可执行文件。
阅读全文