编写一个程序,由键盘终端输入一组无序数,将其用以下方式完成排序:(1)直接插入排序;(2)起泡排序;(3)希尔排序;(4)快速排序;(5)简单选择排序。并在实验结果分析与讨论出分析不同排序方式的优缺点。
时间: 2023-05-01 22:07:31 浏览: 66
这道题让我们编写一个程序,由键盘终端输入一组无序数组,将其用以下方式完成排序:(1)直接插入排序;(2)起泡排序;(3)希尔排序;(4)快速排序;(5)简单选择排序。然后,在分析结果和讨论出分析不同排序方式的优缺点。
相关问题
c语言编写冒泡程序对输入的15个无序整数排序。要求,编写3个子函数;1个为数组输入数据,1个为排序,一个为输出数组数据(输出结果5个一行显示)。主函数调用子函数来完成冒泡排序。
好的,我可以为您提供一个C语言编写冒泡排序程序的示例,其中包括三个子函数和一个主函数。请注意,您提供的15个无序整数将在程序中被硬编码,但您可以根据需要将其更改为其他值:
```c
#include <stdio.h>
void input_arr(int arr[], int n) {
printf("请输入%d个整数:\n", n);
for (int i = 0; i < n; i++) {
scanf("%d", &arr[i]);
}
}
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 tmp = arr[j];
arr[j] = arr[j+1];
arr[j+1] = tmp;
}
}
}
}
void output_arr(int arr[], int n) {
printf("排序后的结果:\n");
for (int i = 0; i < n; i++) {
printf("%d ", arr[i]);
if ((i+1) % 5 == 0) {
printf("\n");
}
}
}
int main() {
int arr[15] = {23, 8, 15, 7, 11, 16, 29, 35, 19, 27, 12, 4, 9, 21, 3};
input_arr(arr, 15);
bubble_sort(arr, 15);
output_arr(arr, 15);
return 0;
}
```
此程序中的 `input_arr` 函数用于从命令行接受用户输入的整数, `bubble_sort` 函数用于执行冒泡排序算法, `output_arr` 函数用于将排序结果按照每行5个整数的格式打印到屏幕上。主函数调用这三个函数来完成整个冒泡排序的过程。注意,调用这三个子函数的顺序很重要,否则您将无法得到正确的结果。
编写一个完整C语言程序,采用两种排序方法实现对某一组无序序列的非递减排序操作。在主程序中输入初始序列,调用排序算法进行排序,输出排序结果。
好的,以下是一份实现题目要求的 C 语言程序,其中使用了插入排序和冒泡排序两种排序算法:
```c
#include <stdio.h>
void insertionSort(int arr[], int n) {
int i, key, j;
for (i = 1; i < n; i++) {
key = arr[i];
j = i - 1;
while (j >= 0 && arr[j] > key) {
arr[j + 1] = arr[j];
j = j - 1;
}
arr[j + 1] = key;
}
}
void bubbleSort(int arr[], int n) {
int i, j;
for (i = 0; i < n - 1; i++) {
for (j = 0; j < n - i - 1; j++) {
if (arr[j] > arr[j + 1]) {
int temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
}
}
}
int main() {
int n;
printf("请输入要排序的数字个数:");
scanf("%d", &n);
int arr[n];
printf("请输入要排序的数字:");
for (int i = 0; i < n; i++) {
scanf("%d", &arr[i]);
}
insertionSort(arr, n);
printf("插入排序结果:");
for (int i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
printf("\n");
bubbleSort(arr, n);
printf("冒泡排序结果:");
for (int i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
printf("\n");
return 0;
}
```
使用时,用户需要输入数字个数和数字序列,程序会先使用插入排序和冒泡排序对序列进行排序,然后输出排序结果。
注意:本程序中的排序算法只是两种简单的排序算法,实际使用时可能需要考虑更复杂的情况和更高效的算法。
阅读全文