[C++面试题]之冒泡排序
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++面试题]之冒泡排序相关推荐
- 前端开发面试题—JavaScript冒泡排序
今天分享一下我遇到的一个关于JavaScript冒泡排序的面试题,题目是笔试题目,要求用JavaScript手写一个冒泡排序,倒序输出新的数组.其实难度不大,就是太久没手写代码在纸上了,感觉有点奇怪( ...
- 面试题:冒泡排序的优化
var arr = [1, 3, 3, 4, 6, 7] for (var i = 0; i < arr.length - 1; i++) {var bool = true;for (var j ...
- Linux上Java的安装与配置,java初级面试笔试题
我总结出了很多互联网公司的面试题及答案,并整理成了文档,以及各种学习的进阶学习资料,免费分享给大家. 扫描二维码或搜索下图红色VX号,加VX好友,拉你进[程序员面试学习交流群]免费领取.也欢迎各位一起 ...
- JAVA面试题大全,收藏这一篇就够了
作者: 星哥 Wechat/QQ: 574373426 整理不易,感谢支持,欢迎 收藏转发分享, 专注IT职业教育多年,学编程找星哥 目录 JAVA基础 数据库 前端 JAVAWEB 框架 微服务/高 ...
- javascript数组——新建数组、访问数组、遍历数组的方法、数组对象的方法、冒泡排序算法、json的正反序列化
目录 数组 通过构造函数的三种方法 字面量创建数组方式 访问数组 遍历数组的方法 遍历:遍历就是把数组中的元素从头到尾都访问一次 操作数组对象的方法 删除和添加 delete与Vue.delete区别 ...
- python高级面试题_10个高级python面试问题
python高级面试题 With Python becoming more and more popular lately, many of you are probably undergoing t ...
- Unity面试】 2022年Unity面试题分享
[重点面试题]代表面试的时候问到的题目 光背答案是没有用的,一定要动手操作一下,才能知道答案为什么是这个. 本文章力求从简单的形式到深入理解原理,再到扩展,丰富知识的层次感,知其所以然. 在文末为大家 ...
- 【数据结构】单链表的逆序输出(两种方法)
第一种方法:转换指针方向 即:将一个已经创建好的单链表进行指针域的改变 今天突然被问到单链表逆序的问题,弄了好久才看出别人的程序有啥问题,就重新写了一遍. 今天才在CSDN客户端上看到美团的面试题是冒 ...
- 小程序 -- [sitemap 索引情况提示] 根据 sitemap 的规则[0],当前页面 [pages/index/index] 将被索引
当一个有稍微强迫症的人看到控制台有一堆的警告的时候,虽然不碍事,但是会很碍眼,会觉得特别难受,所以,我的第一件事就是要先把这些警告干掉先. 第一个警告得问下同事这些配置有什么特殊意义,那先干掉第二个吧 ...
- Avoid mutating a prop directly since the value will be overwritten whenever the parent component re-
原因: 子组件改了父组件的值 避免修改父组件传过来的值 注意: 如果value是obj,需要进行深拷贝. 可以参考: https://blog.csdn.net/u013948858/article/ ...
最新文章
- 一份来自大厂算法工程师的求职宝典
- PostgreSQL — 常规操作
- python 使用@property 来限制类属性的外部更改
- C语言中 怎样区分八进制 十进制 二进制?
- Appium移动自动化框架
- Java每天10道面试题,跟我走,offer有!(七)
- 编写边界条件测试用例原则
- 使用Ant实现打包jar包上传到服务器
- 路由(一)——路由原理及静态路由
- 黑科技轮胎:有能发电的,脑洞简直不要太大...
- 10个必知的网页设计术语计算机与网络,计算机网络专业毕业论文-网页设计与制作(23页)-原创力文档...
- ag 搜索工具参数详解
- python123判断性别程序_听说听胎心能够预测宝宝性别?这是真的吗?
- 数据科学和人工智能技术笔记 十二、逻辑回归
- 【ActiveMQ】消息生产者自动注入报错:Could not autowire. No beans of 'JmsMessagingTemplate' type found
- 展示浏览 java_java利用 cookie 进行展示你所浏览过的的商品
- “站长也疯狂,开车盛宴”——如何选择运维产品
- 易语言组合框基本属性方法事件
- 【Opencv综合应用】自制训练集的人脸识别1——拍摄10张人脸图片
- Nodejs手把手教程