捐助郴维网
感谢您对郴维网的支持,你的支持将是郴维网持续发展的动力!
二维码
×
当前位置:郴维网 >查找和排序 > 正文
17 2024.01

排序算法4 - 冒泡排序

点击次数:11 更新时间:2024/1/17 20:59:47  【打印此页

冒泡排序(Bubble Sort),是一种计算机科学领域的较简单的排序算法。

 

冒泡排序算法的原理如下:

1. 比较相邻的元素。如果第一个比第二个大,就交换他们两个。

2. 对每一对相邻元素做同样的工作,从开始第一对到结尾的最后一对。在这一点,最后的元素应该会是最大的数。

3. 针对所有的元素重复以上的步骤,除了最后一个。

4. 持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较。

 

演示图:

 

代码:

本例代码使用的是从后往前冒泡。

#include <stdio.h>

void BubbleSort(int k[], int n)
{
	int i, j;

	for(i=0; i<n-1; i++)
	{
		for(j=n-1; j>i; j--)
		{
			if( k[j-1]>k[j] )
			{
				k[j] ^= k[j-1];
				k[j-1] ^= k[j];
				k[j] ^=k[j-1];
			}
		}
	}
}


int main(void)
{

	int i;
	int a[10] = {5, 2, 6, 0, 3, 9, 1, 7, 4, 8};

	BubbleSort(a, 10);

	printf("排序后的结果是:");
	for(i=0; i<10; i++)
	{
		printf("%d", a[i]);
		if(i!=9)
		{
			printf(",");
		}
	}
	printf("\n");
	return 0;
}

冒泡排序优化:

优化原理是对已经有序的序列减少循环次数和大小判断次数。如图:

 

优化后的代码:

#include <stdio.h>

void BubbleSort(int k[], int n)
{
	int i, j, flag;

	flag = 1; 
	for(i=0; i<n-1 && flag; i++)
	{
		for(j=n-1; j>i; j--)
		{
			flag = 0;
			if( k[j-1]>k[j] )
			{
				k[j] ^= k[j-1];
				k[j-1] ^= k[j];
				k[j] ^=k[j-1];
				flag = 1;
			}
		}
	}
}


int main(void)
{

	int i;
	int a[10] = {5, 2, 6, 0, 3, 9, 1, 7, 4, 8};

	BubbleSort(a, 10);

	printf("排序后的结果是:");
	for(i=0; i<10; i++)
	{
		printf("%d", a[i]);
		if(i!=9)
		{
			printf(",");
		}
	}
	printf("\n");
	return 0;
}
提示
郴维网为您提供各类专业服务:
软件开发,电脑配件销售,WIFI路由器销售,上门电脑维修,上门安装系统,系统安装,软、硬件安装,电脑除尘清灰,显示器维修,WIFI安装调试,服务器维护,数据恢复,密码破解,网络布线,网络检修,打印机维修,打印机加碳粉,苹果电脑安装系统,苹果电脑安装双系统,监控安装维护,电脑外包,笔记本电脑维修,餐饮、美容行业软件安装 等。。。。。。
点击次数:11 更新时间:2024/1/17 20:59:47  【打印此页
关键词推荐:郴州电脑城 郴州电脑维修公司 维修电脑公司 郴州软件开发 上门电脑维修 上门安装系统 笔记本电脑维修 郴州打印机维修 打印机加碳粉 电脑安装双系统 苹果电脑双系统 液晶显示器维修 联想笔记本维修 联想笔记本维修电话 戴尔笔记本维修电话 郴州戴尔笔记本维修 戴尔笔记本郴州维修点 华硕笔记本维修点 郴州华硕笔记本维修 郴州笔记本上网维修