数据结构学习(十五)——冒泡排序

来源:互联网 发布:电子风水罗盘软件 编辑:程序博客网 时间:2024/05/29 16:22

在前篇的选择排序中,n个数据最多进行n-1次交换,但每次交换前要进行大量比较操作来确定交换对象,比较次数远大于交换次数。而交换操作只是数据的读写,数据规模较小时,其工作量比比较工作量小。用增加交换的次数来减少比较次数有可能是合理的,所以冒泡排序的好处是以交换为主要手段。如果排序对象基本有序时,冒泡排序算法将具有较高的效率。这是因为冒泡排序中有个标志变量是用于提前终止排序的,也即排序可以半途终止。

下面的代码进行了冒泡排序的练习。

#include <stdio.h>#define MAXSIZE 50void Bubble_sort(int *s, int n);int main(void){int n, i;int s[MAXSIZE + 1];printf("冒泡排序练习\n");printf("输入排序数据个数:");scanf("%d", &n);getchar();printf("依次输入数据\n");for(i=1; i<=n; i++)scanf("%d", &s[i]); Bubble_sort(s, n);printf("排序后的数据为\n");for(i=1; i<=n; i++)printf("%d ", s[i]);printf("\n"); return 0;}void Bubble_sort(int *s, int n){int i, j, k;int flag = 0;//交换标志变量for(i=1; i<=n; i++){flag = 1;for(j=n; j>i; j--)//从后向前查找最小值{if(s[j] < s[j-1]){s[0] = s[j];s[j] = s[j-1];s[j-1] = s[0];flag = 0;}}if(flag)//已经有序,提前终止排序break;}}

冒泡排序算法的时间复杂度为O(n^2)。

其算法操作有两部分,一种是比较操作,一种是交换操作。冒泡排序可以进行静态排序,但效率不高。也可以动态排序,但工作量比插入算法大一些(交换次数多一些)。最适合半动态排序,即每生成若干数据排序一次。

该算法需要的资源也比较少,只需要一个备用单元和3个辅助变量。

原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 京东快递退货取件一直取不到怎么办 在京东线上付款了但没收到货怎么办 寄快递收件人电话号码写错了怎么办 京东购物实名认证被别人占用怎么办 货已发出单号还没填买家退货怎么办 自提柜还有一个包忘记拿怎么办 当顾客说衣服太贵的时候怎么办 京东快递送错了被别人签收了怎么办 乐视1s玩王者荣耀卡怎么办 京东商城买东西发现地址错了怎么办 京东分期付款买手机额度不够怎么办 亮皮银色高跟鞋时间放久变色怎么办 饿了么商家钱包提现被锁了怎么办 在淘手游买的游戏账号被找回怎么办 交易猫买手游梦幻号被找回了怎么办 绑定着苹果账号的邮箱忘记了怎么办 京东注册账号跟密码都忘记了怎么办 孩子大学一个宿舍宿友不行怎么办 微信手机支付密码忘记了怎么办 微信公众号不能付款了怎么办 头条误点了投放头条广告怎么办 交行网银密码错误6次怎么办 宁波新冮厦关门我们的消费卡怎么办 第一天上班别人教的学不会怎么办 老公出轨已经不想跟你爱爱了怎么办 妻子出轨丈夫为了孩子不离婚怎么办 妻子出轨分居死也不愿意离婚怎么办 拼多多个人卖家登录密码忘了怎么办 微信被限制添加更多订阅号了怎么办 知网复制粘贴的论文有格式怎么办 知网论文查询网站密码忘记了怎么办 开通了超级会员不能克隆好友怎么办 偷了家里好多钱去买手机了怎么办 中行信用卡短信邀请办白金卡怎么办 注册邮箱说邮箱地址已被注册怎么办 便利店开在小区里面没生意怎么办 微信支付密码忘了怎么办没银行卡 中行5月扣很多钱是怎么办 中银淘宝校园卡影响征信问题怎么办 中银E盾快到期了怎么办 京东e卡电子卡卡密泄漏怎么办