十大常用的排序算法之冒泡排序 C#实现
发布日期:2021-07-22 10:54:31
浏览次数:4
分类:技术文章
本文共 1610 字,大约阅读时间需要 5 分钟。
十大常用的排序算法之冒泡排序 C#实现
最近想换一份工作,所以把之前所学习过的算法知识捡起来复习一遍。废话不多说,首先从最简单的冒泡排序开始。
算法描述
什么是冒泡排序呢?冒泡排序,英文名"Bubble Sort"。它就像水中漂浮的一组气泡一样排列整齐的上升(bulu~ bulu~)。而在这些气泡之中,体积大一些的气泡的上升的速度更快一些,最先浮出水面。 冒泡排序就如同这些气泡一般,依次比较相邻数据的大小,将较小数据放在前面,较大的数据放在后面。例如,对于一个n个元素的数组,第一次比较第1个元素和第2个元素,如果元素1 > 元素2,那么将元素1和元素2调换位置;再比较第2个元素和第3个元素,同样使较小元素放在前面,较大的元素放在后面;依次类推…直至完成比较第n-1个元素和n个元素的大小,这样便完成一次循环。我们可以找到一个“最大的气泡(元素)”,让“大气泡”先浮出水面。举个栗子:现在我们有一个无序数组{7,1,24,11,8}
第一轮循环的比较过程
第一次比较(比较第1,2个元素) 7比1大,交换!第二次比较(比较第2,3个元素)
7小于24,不做变化。第三次比较(比较第3,4个元素)
24大于11,两者交换!第四次比较(比较第4,5个元素)
显然24远远大于8,交换。OK!第一轮的循环做完啦,显然我们找到了那个最大的“气泡”,并且把它置于数组的最末端。再进行下一次循环可以找到第二大的“气泡”,依次类推直到第n-1次循环过后(n为数组中元素的个数),得到下列有序数组{1,7,8,11,24}
算法实现 C#// 冒泡排序 public static int[] BubbleSort(int[] arr) { for (int i = 0; i < arr.Length; i++) { //定义一个Flag用来判断在一次循坏的过程中是否发生了交换 bool isExchanged = false; for (int j = 0; j < arr.Length - 1 - i; j++) { if (arr[j + 1] < arr[j]) { int temp = arr[j + 1]; arr[j + 1] = arr[j]; arr[j] = temp; //如果在本次循环中发生了交换,isExchanged设为Ture. isExchanged = true; } } //如果在一次循环中没有发生过交换,说明该数组已经是有序数组,跳出循环即可. if (!isExchanged) { break; } } return arr; }
算法分析
冒泡排序是稳定排序(),平均时间复杂度为O(n2),空间复杂度O(1)。(注:最好的情况下,仅需要一次循环就可以得到一个有序数组,时间复杂度为O(n))转载地址:https://blog.csdn.net/m0_56500170/article/details/115190356 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
路过,博主的博客真漂亮。。
[***.116.15.85]2024年04月11日 13时04分44秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
maven中的setting.xml 配置文件
2019-04-26
MySQL的Limit详解
2019-04-26
java \t,\n,\r,\b,\f 的作用
2019-04-26
java8 LocalDate 根据时间获取星期几
2019-04-26
Base64 加密解密
2019-04-26
Excel表格身份证号显示不完整问题
2019-04-26
今日份实操——(HTML+CSS)浮动布局练习
2019-04-26
2011年下半年信息系统项目管理师上午试卷试题及参考答案,考试真题
2019-04-26
2011年下半年信息系统项目管理师考试下午案例分析试题及参考答案,考试真题
2019-04-26
2019年上半年信息系统项目管理师考试真题及答案(包含综合知识,案例分析,论文真题)
2019-04-26
理财启蒙必读书籍《小钱狗狗》心得
2019-04-26
《巴比伦最富有的人》精髓:学会储蓄、谨慎投资,从而走上致富之路
2019-04-26
《不可不知的经济真相》精髓:普通老百姓如何进行楼市和股市的投资
2019-04-26
《中国债券市场》精髓:中国债券市场由政府主导,其最重要的目的是为国家建设筹集资金
2019-04-26
《极简GDP史》精髓:GDP虽有诸多局限性,但是对于社会经济发展仍然有举足轻重的作用
2019-04-26
《经济学是什么》精髓:如何用经济学家的眼光理解个人选择和市场经济?
2019-04-26