赞
踩
冒泡排序是一种简单的排序算法,它通过比较相邻元素的大小,并根据需要交换它们的位置来排序数据。它的名称来自于越小的元素会慢慢“冒泡”到数组的开头。
冒泡排序的基本思想是从数组的第一个元素开始,依次比较相邻的两个元素的大小,并根据需要进行交换,使较大的元素逐渐向数组的末尾移动。在一次遍历中,最大的元素会被交换到数组的最后一个位置。然后,再进行下一次遍历,但这次只需比较到倒数第二个元素,依次类推。每次遍历都会将当前未排序的最大元素放置到正确的位置。
如下图(图片来源于图解算法使用C语言):
从上面我们可以看到,第一次先对55和23进行比较,如果其中的一个大于另一个则进行互换,假设55号大于23号中的元素。然后在接着对55号和87号进行比较,就这样一直比较下去,直到完成确定完整的为止。
#include <stdio.h>
void bubbleSort(int arr[], int size)
{
for (int i = 0; i < size - 1; i++)
{
for (int j = 0; j < size - 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 arr[] = {5, 2, 8, 12, 1, 6};
int size = sizeof(arr) / sizeof(arr[0]);
printf("原始数组:");
for (int i = 0; i < size; i++)
{
printf("%d ", arr[i]);
}
bubbleSort(arr, size);
printf("\n排序后的数组:");
for (int i = 0; i < size; i++)
{
printf("%d ", arr[i]);
}
return 0;
}
运行结果:
#include <stdio.h>
// 定义结构体
typedef struct
{
int value;
} Element;
// 定义枚举类型
typedef enum
{
ASCENDING,
DESCENDING
} SortOrder;
// 冒泡排序函数
void bubbleSort(Element arr[], int size, SortOrder sortOrder)
{
int i, j;
Element temp;
for (i = 0; i < size - 1; i++)
{
for (j = 0; j < size - i - 1; j++)
{
// 根据排序顺序进行比较
if ((sortOrder == ASCENDING && arr[j].value > arr[j + 1].value) ||
(sortOrder == DESCENDING && arr[j].value < arr[j + 1].value))
{
// 交换元素
temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
}
}
}
int main()
{
Element arr[] =
{
{5},
{2},
{8},
{1},
{9}
};
int size = sizeof(arr) / sizeof(Element);
int i;
printf("原始数组: ");
for (i = 0; i < size; i++)
{
printf("%d ", arr[i].value);
}
printf("\n");
// 升序排序
bubbleSort(arr, size, ASCENDING);
printf("排序数组(升序): ");
for (i = 0; i < size; i++)
{
printf("%d ", arr[i].value);
}
printf("\n");
// 降序排序
bubbleSort(arr, size, DESCENDING);
printf("排序数组(降序): ");
for (i = 0; i < size; i++)
{
printf("%d ", arr[i].value);
}
printf("\n");
return 0;
}
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。