1、排序方法
    将被排序的记录数组R[1..n]垂直排列,每个记录R[i]看作是重量为R[i].key的气泡。根据轻气泡不能在重气泡之下的原则,从下往上扫描数组R:凡扫描到违反本原则的轻气泡,就使其向上"飘浮"。如此反复进行,直到最后任何两个气泡都是轻者在上,重者在下为止。
(1)初始
     R[1..n]为无序区。
(2)第一趟扫描
     从无序区底部向上依次比较相邻的两个气泡的重量,若发现轻者在下、重者在上,则交换二者的位置。即依次比较(R[n],R[n-1]),(R[n-1],R[n-2]),…,(R[2],R[1]);对于每对气泡(R[j+1],R[j]),若R[j+1].key<R[j].key,则交换R[j+1]和R[j]的内容。
    第一趟扫描完毕时,"最轻"的气泡就飘浮到该区间的顶部,即关键字最小的记录被放在最高位置R[1]上。
(3)第二趟扫描
     扫描R[2..n]。扫描完毕时,"次轻"的气泡飘浮到R[2]的位置上……
    最后,经过n-1 趟扫描可得到有序区R[1..n]
  注意:
     第i趟扫描时,R[1..i-1]和R[i..n]分别为当前的有序区和无序区。扫描仍是从无序区底部向上直至该区顶部。扫描完毕时,该区中最轻气泡飘浮到顶部位置R[i]上,结果是R[1..i]变为新的有序区。


2、冒泡排序过程示例
    对关键字序列为49 38 65 97 76 13 27 49的文件进行冒泡排序的过程【参见动画演示】


3、排序算法
(1)分析
    因为每一趟排序都使有序区增加了一个气泡,在经过n-1趟排序之后,有序区中就有n-1个气泡,而无序区中气泡的重量总是大于等于有序区中气泡的重量,所以整个冒泡排序过程至多需要进行n-1趟排序。
    若在某一趟排序中未发现气泡位置的交换,则说明待排序的无序区中所有气泡均满足轻者在上,重者在下的原则,因此,冒泡排序过程可在此趟排序后终止。为此,在下面给出的算法中,引入一个布尔量exchange,在每趟排序开始前,先将其置为FALSE。若排序过程中发生了交换,则将其置为TRUE。各趟排序结束时检查exchange,若未曾发生过交换则终止算法,不再进行下一趟排序。

(2)具体算法

代码如下:

 void BubbleSort(SeqList R){ //R(l..n)是待排序的文件,采用自下向上扫描,对R做冒泡排序int i,j;Boolean exchange; //交换标志for(i=1;i<n;i++){ //最多做n-1趟排序exchange=FALSE; //本趟排序开始前,交换标志应为假for(j=n-1;j>=i;j--) //对当前无序区R[i..n]自下向上扫描if(R[j+1].key<R[j].key){//交换记录R[0]=R[j+1]; //R[0]不是哨兵,仅做暂存单元R[j+1]=R[j];R[j]=R[0];exchange=TRUE; //发生了交换,故将交换标志置为真}if(!exchange) //本趟排序未发生交换,提前终止算法return;} //endfor(外循环)} //BubbleSort

4、算法分析
(1)算法的最好时间复杂度
    若文件的初始状态是正序的,一趟扫描即可完成排序。所需的关键字比较次数C和记录移动次数M均达到最小值:
        Cmin=n-1
        Mmin=0。
    冒泡排序最好的时间复杂度为O(n)。
(2)算法的最坏时间复杂度
    若初始文件是反序的,需要进行n-1趟排序。每趟排序要进行n-i次关键字的比较(1≤i≤n-1),且每次比较都必须移动记录三次来达到交换记录位置。在这种情况下,比较和移动次数均达到最大值:
        Cmax=n(n-1)/2=O(n2)
        Mmax=3n(n-1)/2=O(n2)
    冒泡排序的最坏时间复杂度为O(n2)。
(3)算法的平均时间复杂度为O(n2)
    虽然冒泡排序不一定要进行n-1趟,但由于它的记录移动次数较多,故平均时间性能比直接插入排序要差得多。
(4)算法稳定性
    冒泡排序是就地排序,且它是稳定的。

完整代码:

#include <iostream>
using namespace std;void BubbleSort(int *list,int len)
{int i,j,temp;for(i=0;i<len;i++)for(j=0;j<len-i;j++){if(list[j]>list[j+1]){temp=list[j];list[j]=list[j+1];list[j+1]=temp;}}
}int main ()
{int list[10];int n=10,m=0;cout<<"Input ten number:";for(int i=0;i<10;i++)cin>>list[i];cout<<endl;BubbleSort(list,n);for(int i=0;i<10;i++)cout<<list[i]<<" ";cout<<endl;
}

转载于:https://www.cnblogs.com/iuices/archive/2011/11/13/2247193.html

[C++面试题]之冒泡排序相关推荐

  1. 前端开发面试题—JavaScript冒泡排序

    今天分享一下我遇到的一个关于JavaScript冒泡排序的面试题,题目是笔试题目,要求用JavaScript手写一个冒泡排序,倒序输出新的数组.其实难度不大,就是太久没手写代码在纸上了,感觉有点奇怪( ...

  2. 面试题:冒泡排序的优化

    var arr = [1, 3, 3, 4, 6, 7] for (var i = 0; i < arr.length - 1; i++) {var bool = true;for (var j ...

  3. Linux上Java的安装与配置,java初级面试笔试题

    我总结出了很多互联网公司的面试题及答案,并整理成了文档,以及各种学习的进阶学习资料,免费分享给大家. 扫描二维码或搜索下图红色VX号,加VX好友,拉你进[程序员面试学习交流群]免费领取.也欢迎各位一起 ...

  4. JAVA面试题大全,收藏这一篇就够了

    作者: 星哥 Wechat/QQ: 574373426 整理不易,感谢支持,欢迎 收藏转发分享, 专注IT职业教育多年,学编程找星哥 目录 JAVA基础 数据库 前端 JAVAWEB 框架 微服务/高 ...

  5. javascript数组——新建数组、访问数组、遍历数组的方法、数组对象的方法、冒泡排序算法、json的正反序列化

    目录 数组 通过构造函数的三种方法 字面量创建数组方式 访问数组 遍历数组的方法 遍历:遍历就是把数组中的元素从头到尾都访问一次 操作数组对象的方法 删除和添加 delete与Vue.delete区别 ...

  6. python高级面试题_10个高级python面试问题

    python高级面试题 With Python becoming more and more popular lately, many of you are probably undergoing t ...

  7. Unity面试】 2022年Unity面试题分享

    [重点面试题]代表面试的时候问到的题目 光背答案是没有用的,一定要动手操作一下,才能知道答案为什么是这个. 本文章力求从简单的形式到深入理解原理,再到扩展,丰富知识的层次感,知其所以然. 在文末为大家 ...

  8. 【数据结构】单链表的逆序输出(两种方法)

    第一种方法:转换指针方向 即:将一个已经创建好的单链表进行指针域的改变 今天突然被问到单链表逆序的问题,弄了好久才看出别人的程序有啥问题,就重新写了一遍. 今天才在CSDN客户端上看到美团的面试题是冒 ...

  9. 小程序 -- [sitemap 索引情况提示] 根据 sitemap 的规则[0],当前页面 [pages/index/index] 将被索引

    当一个有稍微强迫症的人看到控制台有一堆的警告的时候,虽然不碍事,但是会很碍眼,会觉得特别难受,所以,我的第一件事就是要先把这些警告干掉先. 第一个警告得问下同事这些配置有什么特殊意义,那先干掉第二个吧 ...

  10. Avoid mutating a prop directly since the value will be overwritten whenever the parent component re-

    原因: 子组件改了父组件的值 避免修改父组件传过来的值 注意: 如果value是obj,需要进行深拷贝. 可以参考: https://blog.csdn.net/u013948858/article/ ...

最新文章

  1. 一份来自大厂算法工程师的求职宝典
  2. PostgreSQL — 常规操作
  3. python 使用@property 来限制类属性的外部更改
  4. C语言中 怎样区分八进制 十进制 二进制?
  5. Appium移动自动化框架
  6. Java每天10道面试题,跟我走,offer有!(七)
  7. 编写边界条件测试用例原则
  8. 使用Ant实现打包jar包上传到服务器
  9. 路由(一)——路由原理及静态路由
  10. 黑科技轮胎:有能发电的,脑洞简直不要太大...
  11. 10个必知的网页设计术语计算机与网络,计算机网络专业毕业论文-网页设计与制作(23页)-原创力文档...
  12. ag 搜索工具参数详解
  13. python123判断性别程序_听说听胎心能够预测宝宝性别?这是真的吗?
  14. 数据科学和人工智能技术笔记 十二、逻辑回归
  15. 【ActiveMQ】消息生产者自动注入报错:Could not autowire. No beans of 'JmsMessagingTemplate' type found
  16. 展示浏览 java_java利用 cookie 进行展示你所浏览过的的商品
  17. “站长也疯狂,开车盛宴”——如何选择运维产品
  18. 易语言组合框基本属性方法事件
  19. 【Opencv综合应用】自制训练集的人脸识别1——拍摄10张人脸图片
  20. Nodejs手把手教程

热门文章

  1. Log4j 2.x使用遇到的问题
  2. 90 岁程序员,他的压缩算法改变了世界!
  3. 卧槽!新来的妹纸rm -rf把公司整个数据库删没了,整个项目组慌了~
  4. 别乱提交代码了,你必须知道的 Git 分支开发规范!
  5. 震惊!Redis 的字符串居然是这样实现的…
  6. 超全面的权限系统设计方案!
  7. 我是如何把SpringBoot项目的并发提升十倍量级的
  8. 都说 NoSQL 比 SQL 强,一文揭密 NoSQL 到底有多强!
  9. mysql基础之mariadb集群双主(主主)架构
  10. gradle脚本源码查看环境搭建