排序——冒泡排序

举报
ruochen 发表于 2021/03/27 23:50:24 2021/03/27
【摘要】 冒泡排序基本思想算法实现算法分析 冒泡排序 基本思想 依次比较相临两个数据元素的大小,若逆序则交换两个数据元素,否则不交换。当完成一趟交换以后,最大的元素将会出现在数据序列的最后一个位置。重复以上过程,直到待排序序列中没有逆序为止。 每趟结束时,不仅能挤出一个最大值到最后面位置,还能同时部分理顺其他元素; 一旦下趟没有交换,还可提前结束...

冒泡排序

基本思想

  • 依次比较相临两个数据元素的大小,若逆序则交换两个数据元素,否则不交换。
  • 当完成一趟交换以后,最大的元素将会出现在数据序列的最后一个位置。
  • 重复以上过程,直到待排序序列中没有逆序为止。

每趟结束时,不仅能挤出一个最大值到最后面位置,还能同时部分理顺其他元素;
一旦下趟没有交换,还可提前结束排序

算法实现

c++代码实现

// 原始冒泡排序
void bubblf_sort(SqList &L){
	// 从大到小有序
	for(i = 1; i <= L.length; ++i)
		for(j = 1; j <= L.length - 1; j++){ if(L.r[j + 1].key < L.r[j].key){ temp = L.r[j + 1]; L.r[j + 1] = L.r[j]; L.r[j] = temp; } }
}

// 改进后的算法
void bubblf_sort(SqList &L){
	for(i = 1, change = true; i <= L.length - 1 && change; i++){
		change = false;
		for(j = 1; j < L.length - i; ++i) if(L.r[j + 1].key < L.r[j].key){ temp = L.r[j]; L.r[j] = L.r[j + 1]; L.r[j + 1] = temp; change = true; }
	}
}

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27

python代码实现

'''冒泡排序-BubbleSort'''
def bubble_sort(alist):
	for j in range(len(alist)-1,0,-1):
		# j表示每次遍历需要比较的次数,是逐渐减小的
		for i in range(j): if alist[i] > alist[i+1]: alist[i], alist[i+1] = alist[i+1], alist[i]

l = [54, 45, 32, 34, 56, 90]
bubble_sort(l)

print(l)


  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
[32, 34, 45, 54, 56, 90]

  
 
  • 1

算法分析

  • 时间复杂度为 O(n^2)
    • 最好情况下: 只需 1趟排序,比较次数为 n-1,不移动
    • 最坏情况下:需 n-1趟排序,第i趟比较n-i次,移动**3(n-i)**次
  • 空间复杂度为 O(1)
  • 是一种稳定的排序方法

文章来源: ruochen.blog.csdn.net,作者:若尘,版权归原作者所有,如需转载,请联系作者。

原文链接:ruochen.blog.csdn.net/article/details/103802745

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。