冒泡排序

public void swap(int before, int after){
	int temp = param[before];
	param[before] = param[after];
	param[after] = temp;
}
public void sort() {
	if (param != null) {
		int length = param.length;
		for (int i = 0; i < length - 1; i++)
			for (int j = 0; j < length - 1 - i; j++)
				if (param[j] > param[j + 1])
					swap(j,j+1);
	}
}

 


冒泡排序算法:

将每两个元素互相进行比较,总是将大的(小的)的元素往一个方向移动

第一趟两两比较下来之后可以筛选出最大(小)的元素,剩下n-1个元素,

然后再在这些元素里进行两两比较大(小)的往一个方向移动,于是再这些元素里又会找到一个最大(小)的

直到只剩1个元素没有可比较的元素,整个过程就像是一次冒出一个最大(小)的元素,所以取名冒泡排序。

生活中的例子:

军训站队时的个子排序。

例子:

5,3,6,7,2,1;

进行升序排列。

第一步:得到最大值7,放在最后一个位置

1.拿5与3比较,5比3大,交换位置,此时顺序为3,5,6,7,2,1

2.拿5与6比较,6比5大,不交换位置,此时顺序为3,5,6,7,2,1

3.拿6与7比较,7比6大,不交换位置,此时顺序为3,5,6,7,2,1

4.拿7与2比较,7比2大,交换位置,此时顺序为3,5,6,2,7,1

5.拿7与1比较,7比1大,交换位置,此时顺序为3,5,6,2,1,7

第二步:得到次大值6,放在倒数第二个位置

1.拿3与5比较,5比3大,不交换位置,此时顺序为3,5,6,2,1,7

2.拿5与6比较,6比5大,不交换位置,此时顺序为3,5,6,2,1,7

3.拿6与2比较,6比2大,交换位置,此时顺序为3,5,2,6,1,7

4.拿6与1比较,6比1大,交换位置,此时顺序为3,5,2,1,6,7

第三步:得到次次大值5,放在倒数第三个位置

1.拿3与5比较,5比3大,不交换位置,此时顺序为3,5,2,1,6,7

2.拿5与2比较,5比2大,交换位置,此时顺序为3,2,5,1,6,7

3.拿5与1比较,5比1大,交换位置,此时顺序为3,2,1,5,6,7

第四步:得到次次次大值3,放在倒数第四个位置

1.拿3与2比较,3比2大,交换位置,此时顺序为2,3,1,5,6,7

2.拿3与1比较,3比1大,交换位置,此时顺序为2,1,3,5,6,7

第五步:得到次次次大值2,放在倒数第五个位置

1.拿2与1比较,2比1大,交换位置,此时顺序为1,2,3,5,6,7


总结

n为数据总个数

一共进行了n-1趟   两两比较排序   用i(从0开始)表示排序的次数

每趟排序进行了n-1-i次两两比较

时间复杂度

若文件的初始状态是正序的,一趟扫描即可完成排序。所需的关键字比较次数  和记录移动次数  均达到最小值:

所以,冒泡排序最好的时间复杂度 。若初始文件是反序的,需要进行 趟排序。每趟排序要进行 - 1 (0≤i<n-1)次关键字的比较,且每次比较都必须移动记录三次来达到交换记录位置。在这种情况下,比较和移动次数均达到最大值:

冒泡排序的最坏时间复杂度为。综上,因此冒泡排序总的平均时间复杂度为 。

算法稳定性

冒泡排序就是把小的元素往前调或者把大的元素往后调。比较是相邻的两个元素比较,交换也发生在这两个元素之间。所以,如果两个元素相等,我想你是不会再无聊地把他们俩交换一下的;如果两个相等的元素没有相邻,那么即使通过前面的两两交换把两个相邻起来,这时候也不会交换,所以相同元素的前后顺序并没有改变,所以冒泡排序是一种稳定排序算法。


注:时间复杂度与算法稳定性来至百度百科http://baike.baidu.com/view/254413.htm?fr=aladdin#2_1

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值