数组内大小排序。 (三种方法:选择,插入和冒泡,解释区别) (正负数不限定) (整数浮点数不限定) (数字数量0<n<99) (输入n个数用空格隔开,输出由小到大排序后的数组)使用c语言
时间: 2024-10-01 07:04:19 浏览: 34
C语言《一维数组和冒泡算法》完整版资料.ppt
在C语言中,对一组数值(整数、浮点数或正负数)进行排序可以采用不同的算法,包括选择排序、插入排序和冒泡排序。以下是这三种方法的区别:
1. **选择排序(Selection Sort)**:
- 工作原理:每次从未排序的部分找到最小(或最大)元素,将其放到已排序部分的末尾。选择过程独立于当前位置,因此效率较低。
- 时间复杂度:O(n^2),其中n是数组长度。
- 编程示例:遍历整个数组,每次都找出未排序部分的最小值。
2. **插入排序(Insertion Sort)**:
- 动作:从第二个元素开始,将每个元素逐个插入到已经排好序的前一部分的合适位置。如果当前元素比前面所有元素都小,则逐个前移较大的元素。
- 时间复杂度:最好情况O(n),即已排序;最坏和平均情况O(n^2)。
- 插入操作可能导致数据移动较多,但对于部分有序的数据效率较高。
3. **冒泡排序(Bubble Sort)**:
- 运行机制:反复交换相邻的两个元素,如果一轮下来没有任何交换,说明已经排序完成。每轮会把最大的(或最小的)元素“冒”到顶端。
- 时间复杂度:最坏、平均和最好情况都是O(n^2)。
- 冒泡排序直观易懂,但效率低,尤其对于大数组。
对于您提到的场景,例如输入0到98之间的n个任意精度数字,您可以选择编写针对特定数据类型的版本(如int、float等),然后使用上述任一排序算法。这里给出一个简单的冒泡排序C语言函数示例,适用于整数数组:
```c
#include <stdio.h>
void bubble_sort(int arr[], int n) {
for (int i = 0; i < n - 1; ++i) {
for (int j = 0; j < n - 1 - i; ++j) {
if (arr[j] > arr[j + 1]) {
int temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
}
}
}
int main() {
int n, *input;
scanf("%d", &n);
input = malloc(n * sizeof(int));
for (int i = 0; i < n; ++i) {
scanf("%d", &input[i]);
}
bubble_sort(input, n);
for (int i = 0; i < n; ++i) {
printf("%d ", input[i]);
}
printf("\n");
free(input);
return 0;
}
```
阅读全文