频 道 直 达 - 新闻 - 培训 - 软件 - 教程 - 前沿 - 组网 - 系统应用 - 安全 - 编程 - 存储 - 操作系统 - 数据库 - 服务器 - 专题 - 产品 - 案例库 - 读书 - 博客 - BBS
51CTO.COM_中国最大的网络技术网站
找资料:

8.5.2 冒泡法排序实例

作者: 徐磊等编著 出处:电子工业出版社  2008-06-02 12:35    砖    好    评论   进入论坛
阅读提示:《Linux系统下C程序开发详解》第8章讲述了数组与指针。数组与指针的知识是C程序中的重要内容,可以实现很多复杂的功能和算法。数组与指针这两个概念的理解是个难点,需要建立起直观形象的空间概念。在实际开发时各种对象与算法常常通过指针与数组建立起来的,需要使用各种复杂的指针和数组。在程序设计练习时需要注意数组与指针的应用技巧,本节为大家介绍冒泡法排序实例。

8.5.2  冒泡法排序实例

冒泡法排序实例是C语言中的一个经典算法,实现多个数值的排序。方法是多次循环进行比较,每次比较时将最大数移动到最上面。每次循环时,找出剩余变量里的最大值,然后减小查询范围。这样经过多次循环以后,就完成了对这个数组的排序。这种排序的算法可用如图8-1所示的来表示。

冒泡法排序使用了反复循环和比较的算法,执行了下面这些步骤。

在第一次循环时,拿第一个数与第二个数进行比较,如果第一个数小于第二个数,就用一个中间变量使这两个数交换。这样就使第一和第二个数从大到小排列。

  
图8-1  冒泡法排序的算法

再用第一个数与第三个数比较,使这两个数从大到小排列。用同样的方法,用第一个数与后面所有的数进行比较。

经过了第一轮循环比较以后,第一个数一定是所有数里面最大的数。

进行第二轮比较。这时让第二个数与后面所有的数比较,使这个数是这些数里面的最大数。

用循环的方法,依次用后面的一个数与这个数后面的所有数进行比较,这样就完成了这些数的从大到小排序。

下面的程序是冒泡法排序的例子。在这个程序中需要注意两次循环比较。

代码8-11  冒泡法排序:\源文件\08\8.11.c

#include <stdio.h>
main()
{
int a[10];      /*定义一个整型数组。*/
int i,j,temp;      /*定义循环变量和中间变量。*/
for(i=0;i<10;i++)    /*进行循环输入变量。*/
{
printf("please enter a number:\n"); /*输出提示。*/
scanf("%d",&a[i]);    /*输入变量赋值给数组变量。*/
}
for(i=0;i<10;i++)    /*进行10次循环。*/
{
for(j=i+1;j<10;j++)   /*循环比较剩余的变量。*/
{
if(a[i]<a[j])    /*如果前面一个数比后面数小,交换两个数的值。*/
{
temp=a[i];
a[i]=a[j];
a[j]=temp;
}
}
}
for(i=0;i<10;i++)    /*循环输出排序以后的结果。*/
{
printf("%d  ",a[i]);
}
}
编译并运行这一个程序,根据程序的提示输入10个数字,程序会对这些数字进行排序,然后输出排序以后的结果。
【责任编辑:夏书 TEL:(010)68476606】

回书目   上一节   下一节
专题
初探敏捷开发
WCF开发基础
Linux——从菜鸟到高手
Visual Studio 2005开发基础
测试开发人员参考手册
我也说两句

匿名发表

(如果看不清请点击图片进行更换)


中 国 最 大 的 网 络 技 术 网 站 ·
技 术 成 就 梦 想
订阅技术快讯
电子杂志下载
名称:SQL Server数据库管理精品黄皮书
简介:书中文章经过精挑细选,便于用户能根据自己的实际工作和学习,快速在本书寻找到相关资料。内容涵盖了SQL Server的安装与升级、语句查询、数据备份和恢复、自动化任务、数据同步、数据字典、安全和预防、性能和优化、集群等各方面应用信息,以及DBA管理人员在数据库管理工作中
名称:2007路由技术大全
简介:《2007路由技术大全》由51CTO.com网站特别策划制作,该书包括路由器技术、路由器产品、路由器配置、安全设置、路由器故障处理、路由器密码恢复,以及广大网友在实践使用中的心得经验和技巧文章,内容注重实用性,适用于初学者入门,也适合多年从业者提高,是一本实践和理论完
名称:网络安全精品应用黄皮书
简介:《2007精品网络安全黄皮书》包括了9个大类24个小类, 800余篇文章,内容包含了熊猫烧香病毒、DDOS攻击、ARP病等热点问题的介绍及解决方案。从病毒查杀、防范、系统、数据等各方面的安全设置到黑客技术的了解、防范,涉及到了安全应用的全部领域, 由浅至深内容全面。
充电计划之热门IT认证官方资料汇总
充电计划之热门IT认证官方资..
网络工程师的职业规划与生存现状
网络工程师的职业规划与生存..
勇闯IT培训黑色围城
勇闯IT培训黑色围城
· 勇闯IT培训黑色围城
· 如何有效防御SQL注入攻..
· 2008年上半年全国软考..
· 选择适合自己的IT认证
· IPv6协议--拓展网络无..
· 了解统一威胁管理(UTM)..
· 调查:十大发现 解秘技..
· 技术人求职简历完备手册
· Vista SP1对决XP SP3
· 运营商封堵ADSL共享 中..
· LAMP技术精解
· PHP开发应用手册
· 解析35岁技术人的价值..
· 汶川大地震 IT技术人在..
· SOA 面向服务架构
· 龙芯要做中国的“奔腾”
ARP攻击防范与解决方案
ARP攻击防范与解决方案
iSCSI应用与发展
iSCSI应用与发展
SQL Server 2008/2005全解
SQL Server 2008/2005全解
· SQL Server 2008/2005..
· SOA 面向服务架构
· SQL Server 2008/2005..
· iSCSI应用与发展
· RAID——磁盘阵列基础
· Apache技术专题
· 三层交换技术专题
· SQL Server入门到精通
· Apache技术专题
· 国际文档格式标准开战
· 路由器设置与口令恢复
· 打造安全服务器
· PHP开发应用手册
· SOA 面向服务架构
· 企业数据恢复指南
· 了解统一威胁管理(UTM)..
ARP攻击防范与解决方案
ARP攻击防范与解决方案
SQL Server 2008/2005全解
SQL Server 2008/2005全解
iSCSI应用与发展
iSCSI应用与发展
· iSCSI应用与发展
· SQL Server入门到精通
· SQL Server 2008/2005..
· SOA 面向服务架构
· Apache技术专题
· iSCSI应用与发展
· 三层交换技术专题
· Apache技术专题
· RAID——磁盘阵列基础
· 企业数据恢复指南
· 路由器设置与口令恢复
· SOA 面向服务架构
· 了解统一威胁管理(UTM)..
· 反垃圾邮件技术应用
· 访问控制列表(ACL)介绍
· PHP开发应用手册