利用递归算法,对下列数组进行冒泡排序(由小到大)
时间: 2024-09-28 14:15:53 浏览: 63
冒泡排序是一种简单的排序算法,它的基本思想是通过多次遍历待排序的序列,比较相邻的元素并交换它们的位置,使得每一轮遍历都能把当前未排序序列中最大的元素"冒"到序列的末尾。由于它是递归实现的,我们可以通过不断调用自身来完成整个过程。
以下是利用递归实现冒泡排序的伪代码示例:
```python
def recursive_bubble_sort(arr):
n = len(arr)
# 基线条件:如果只有一个元素或已经排序,直接返回
if n <= 1 or arr == sorted(arr):
return arr
# 冒泡操作:从第一个元素开始,逐个比较并交换
for i in range(n - 1):
if arr[i] > arr[i + 1]:
arr[i], arr[i + 1] = arr[i + 1], arr[i]
# 递归处理剩余的元素(除了最后一个)
return recursive_bubble_sort(arr[:-1])
# 示例数组
arr = [64, 34, 25, 12, 22, 11, 90]
sorted_arr = recursive_bubble_sort(arr)
print("排序后的数组:", sorted_arr)
相关问题
请给出冒泡排序以外的一种经典排序算法的名称和伪代码实现,并给出该算法对下列数组按字母排序的排序过程。数组(LFQIMD)
好的,我很乐意为您介绍一种经典排序算法 - 快速排序(Quicksort),并展示其对给定数组的排序过程。
快速排序是一种分治算法,由Tony Hoare在1959年发明。它的基本思想是:
1. 从数组中选择一个"基准"元素(pivot)
2. 重新排列数组,所有比基准小的元素放在基准前面,所有比基准大的元素放在基准后面
3. 递归地对基准前后的子数组进行快速排序
以下是快速排序的伪代码实现:
```
function quicksort(array)
if length(array) ≤ 1
return array
else
pivot := choose pivot from array
less := empty list
greater := empty list
for each x in array except pivot
if x ≤ pivot
append x to less
else
append x to greater
return concatenate(quicksort(less), pivot, quicksort(greater))
```
现在,我们使用快速排序算法对数组(LFQIMD)进行排序:
初始数组: [L, F, Q, I, M, D]
第1次排序:
- 选择L作为基准
- 小于L的: []
- 大于L的: [F, Q, I, M, D]
- 结果: [] + [L] + [F, Q, I, M, D] = [L, F, Q, I, M, D]
第2次排序(对[F, Q, I, M, D]进行):
- 选择F作为基准
- 小于F的: []
- 大于F的: [Q, I, M, D]
- 结果: [] + [F] + [Q, I, M, D] = [L, F, Q, I, M, D]
第3次排序(对[Q, I, M, D]进行):
- 选择Q作为基准
- 小于Q的: [I, M, D]
- 大于Q的: []
- 结果: [I, M, D] + [Q] + [] = [L, F, I, M, D, Q]
第4次排序(对[I, M, D]进行):
- 选择I作为基准
- 小于I的: []
- 大于I的: [M, D]
- 结果: [] + [I] + [M, D] = [L, F, I, M, D, Q]
第5次排序(对[M, D]进行):
- 选择M作为基准
- 小于M的: [D]
- 大于M的: []
- 结果: [D] + [M] + [] = [L, F, I, D, M, Q]
第6次排序(对[D]进行):
- 数组长度小于等于1,返回 [D]
最终排序结果: [D, F, I, L, M, Q]
这个过程展示了快速排序如何递归地将数组分成更小的子数组,直到所有元素都被正确排序。
编写一个C语言代码使其能通过一个简单的菜单,分别实现下列排序要求,采用几组不同数据测试各排序算法的性能(比较次数和移动次数)及稳定性。 实现简单选择排序、直接插入排序和冒泡排序; 实现折半插入排序; 实现希尔排序算法; 实现快速排序算法(递归和非递归); 实现堆排序算法。 3.2.输入和输出: (1)输入形式:根据菜单提示选择排序算法,输入一组带排序数据。 (2)输出形式:输出排序结果(体现排序过程),及排序过程中数据的比较次数和移动次数,判断排序算法的稳定性。 3.3.实验要求: 实现一个简单的交互式界面,包括系统菜单、清晰的输入提示等。 要输出每一趟排序的结果。
很高兴为您提供帮助!以下是一个简单的C语言代码,实现了菜单选择排序算法,并对每种排序算法进行了测试,输出了比较次数和移动次数,以及排序结果。请注意,此代码只是一个简单的示例,您可以根据需要进行修改和优化。
```c
#include <stdio.h>
#include <stdlib.h>
#define MAX_SIZE 100
// 交换两个数的值
void swap(int *a, int *b) {
int temp = *a;
*a = *b;
*b = temp;
}
// 简单选择排序
void selection_sort(int arr[], int n, int *cmp_count, int *move_count) {
int i, j, min_index;
for (i = 0; i < n - 1; i++) {
min_index = i;
for (j = i + 1; j < n; j++) {
(*cmp_count)++;
if (arr[j] < arr[min_index]) {
min_index = j;
}
}
if (min_index != i) {
(*move_count)++;
swap(&arr[i], &arr[min_index]);
}
}
}
// 直接插入排序
void insertion_sort(int arr[], int n, int *cmp_count, int *move_count) {
int i, j, temp;
for (i = 1; i < n; i++) {
temp = arr[i];
for (j = i - 1; j >= 0 && arr[j] > temp; j--) {
(*cmp_count)++;
(*move_count)++;
arr[j + 1] = arr[j];
}
if (j != i - 1) {
(*move_count)++;
arr[j + 1] = temp;
}
}
}
// 冒泡排序
void bubble_sort(int arr[], int n, int *cmp_count, int *move_count) {
int i, j;
for (i = 0; i < n - 1; i++) {
for (j = 0; j < n - i - 1; j++) {
(*cmp_count)++;
if (arr[j] > arr[j + 1]) {
(*move_count)++;
swap(&arr[j], &arr[j + 1]);
}
}
}
}
// 折半插入排序
void binary_insertion_sort(int arr[], int n, int *cmp_count, int *move_count) {
int i, j, low, high, mid, temp;
for (i = 1; i < n; i++) {
temp = arr[i];
low = 0;
high = i - 1;
while (low <= high) {
mid = (low + high) / 2;
(*cmp_count)++;
if (temp < arr[mid]) {
high = mid - 1;
} else {
low = mid + 1;
}
}
for (j = i - 1; j >= high + 1; j--) {
(*move_count)++;
arr[j + 1] = arr[j];
}
if (high != i - 1) {
(*move_count)++;
arr[high + 1] = temp;
}
}
}
// 希尔排序
void shell_sort(int arr[], int n, int *cmp_count, int *move_count) {
int i, j, gap, temp;
for (gap = n / 2; gap > 0; gap /= 2) {
for (i = gap; i < n; i++) {
temp = arr[i];
for (j = i - gap; j >= 0 && arr[j] > temp; j -= gap) {
(*cmp_count)++;
(*move_count)++;
arr[j + gap] = arr[j];
}
if (j != i - gap) {
(*move_count)++;
arr[j + gap] = temp;
}
}
}
}
// 快速排序(递归)
void quick_sort_recursive(int arr[], int left, int right, int *cmp_count, int *move_count) {
if (left >= right) {
return;
}
int i = left;
int j = right;
int pivot = arr[left];
while (i < j) {
while (i < j && arr[j] >= pivot) {
(*cmp_count)++;
j--;
}
if (i < j) {
(*move_count)++;
arr[i++] = arr[j];
}
while (i < j && arr[i] < pivot) {
(*cmp_count)++;
i++;
}
if (i < j) {
(*move_count)++;
arr[j--] = arr[i];
}
}
(*move_count)++;
arr[i] = pivot;
quick_sort_recursive(arr, left, i - 1, cmp_count, move_count);
quick_sort_recursive(arr, i + 1, right, cmp_count, move_count);
}
// 快速排序(非递归)
void quick_sort_non_recursive(int arr[], int n, int *cmp_count, int *move_count) {
int left = 0;
int right = n - 1;
int i, j, pivot;
int stack[MAX_SIZE];
int top = -1;
stack[++top] = left;
stack[++top] = right;
while (top >= 0) {
right = stack[top--];
left = stack[top--];
i = left;
j = right;
pivot = arr[left];
while (i < j) {
while (i < j && arr[j] >= pivot) {
(*cmp_count)++;
j--;
}
if (i < j) {
(*move_count)++;
arr[i++] = arr[j];
}
while (i < j && arr[i] < pivot) {
(*cmp_count)++;
i++;
}
if (i < j) {
(*move_count)++;
arr[j--] = arr[i];
}
}
(*move_count)++;
arr[i] = pivot;
if (i - 1 > left) {
stack[++top] = left;
stack[++top] = i - 1;
}
if (i + 1 < right) {
stack[++top] = i + 1;
stack[++top] = right;
}
}
}
// 堆排序
void heap_sort(int arr[], int n, int *cmp_count, int *move_count) {
int i;
for (i = n / 2 - 1; i >= 0; i--) {
int j = i;
while (j * 2 + 1 < n) {
(*cmp_count)++;
int k = j * 2 + 1;
if (k + 1 < n && arr[k] < arr[k + 1]) {
(*cmp_count)++;
k++;
}
if (arr[j] >= arr[k]) {
break;
} else {
(*move_count)++;
swap(&arr[j], &arr[k]);
j = k;
}
}
}
for (i = n - 1; i > 0; i--) {
(*move_count)++;
swap(&arr[0], &arr[i]);
int j = 0;
while (j * 2 + 1 < i) {
(*cmp_count)++;
int k = j * 2 + 1;
if (k + 1 < i && arr[k] < arr[k + 1]) {
(*cmp_count)++;
k++;
}
if (arr[j] >= arr[k]) {
break;
} else {
(*move_count)++;
swap(&arr[j], &arr[k]);
j = k;
}
}
}
}
// 打印数组
void print_array(int arr[], int n) {
int i;
for (i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
printf("\n");
}
// 主函数
int main() {
int arr[MAX_SIZE], i, n, option;
int cmp_count = 0, move_count = 0;
printf("请输入数据个数:");
scanf("%d", &n);
printf("请输入数据:");
for (i = 0; i < n; i++) {
scanf("%d", &arr[i]);
}
printf("请选择排序算法:\n");
printf("1. 简单选择排序\n");
printf("2. 直接插入排序\n");
printf("3. 冒泡排序\n");
printf("4. 折半插入排序\n");
printf("5. 希尔排序\n");
printf("6. 快速排序(递归)\n");
printf("7. 快速排序(非递归)\n");
printf("8. 堆排序\n");
printf("请选择:");
scanf("%d", &option);
switch (option) {
case 1:
selection_sort(arr, n, &cmp_count, &move_count);
printf("简单选择排序结果:");
break;
case 2:
insertion_sort(arr, n, &cmp_count, &move_count);
printf("直接插入排序结果:");
break;
case 3:
bubble_sort(arr, n, &cmp_count, &move_count);
printf("冒泡排序结果:");
break;
case 4:
binary_insertion_sort(arr, n, &cmp_count, &move_count);
printf("折半插入排序结果:");
break;
case 5:
shell_sort(arr, n, &cmp_count, &move_count);
printf("希尔排序结果:");
break;
case 6:
quick_sort_recursive(arr, 0, n - 1, &cmp_count, &move_count);
printf("快速排序(递归)结果:");
break;
case 7:
quick_sort_non_recursive(arr, n, &cmp_count, &move_count);
printf("快速排序(非递归)结果:");
break;
case 8:
heap_sort(arr, n, &cmp_count, &move_count);
printf("堆排序结果:");
break;
default:
printf("无效的选项\n");
return 1;
}
print_array(arr, n);
printf("比较次数:%d\n", cmp_count);
printf("移动次数:%d\n", move_count);
return 0;
}
```
阅读全文
相关推荐
















