武汉理工课程设计封面.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
武汉理工课程设计封面.doc

课程设计任务书 学生姓名: XX 专业班级:计算机科学与技术 指导教师: XX 工作单位: 计算机科学系 题 目: 快速排序与冒泡排序算法比较 初始条件: 试分别实现冒泡排序和非递归形式的快速排序算法,并通过随机数据比较两种排序算法中关键字的比较次数和移动次数。 (1)待排序表的表长不小于100;其中的数据要用伪随机数产生程序产生;至少要用5组不同的输入数据作比较;比较的指标为有关键字参加的比较次数和关键字的移动次数(关键字交换计为3次移动)。 (2)最后要对结果作出简单分析,包括对各组数据得出结果波动大小的解释。 (3)对冒泡排序应指出进行了多少趟。 要求完成的主要任务: (包括课程设计工作量及其技术要求,以及说明书撰写等具体要求) 课程设计报告按学校规定格式用A4纸打印(书写),并应包含如下内容: 1. 问题描述 简述题目要解决的问题是什么。 2. 设计 存储结构设计、主要算法设计(用类C/C++语言或用框图描述)、测试用例设计; 3. 调试报告 调试过程中遇到的问题是如何解决的;对设计和编码的讨论和分析。 4. 经验和体会(包括对算法改进的设想) 5. 附源程序清单和运行结果。源程序要加注释。如果题目规定了测试数据,则运行结果要包含这些测试数据和运行输出。 说明: 1. 设计报告、程序不得相互抄袭和拷贝;若有雷同,则所有雷同者成绩均为0分。 2. 凡拷贝往年任务书或课程设计充数者,成绩一律无效,以0分记。 时间安排: 1、6月15日~6月21日完成。 2、6月22日上午和下午在实验中心检查程序、交课程设计报告、源程序(U盘)。 指导教师签名: 2012年6月14日 系主任(或责任教师)签名: 年 月 日 目 录 1问题分析和任务定义........................... 3 2.开发平台......................................3 3.程序设计......................................3 4.调试结果与运行情况分析........................6 5.自我评价与总结................................12 6.课程设计参考资料..............................12 问题分析和任务定义 1.1问题分析 编程实现快速、冒泡两种排序算法,两者之间的算法好坏比较主要有两个方面:数据比较次数和数据移动次数。在该程序中,首先对两种排序算法进行实现,然后再进行比较。 1.2任务定义 1.2.1冒泡排序定义 冒泡排序又称起泡排序,它也是一种简单实用的排序方法。其基本思想是通过相邻记录之间关键字的比较和交换,使关键字值较小的记录逐渐的从底部移向顶部,即从下标较大的单元移向下标较小的单元,就像水底的气泡一样逐渐向上冒;而关键字较大的记录就像石块往下沉一样,每一趟有一块“最大”的石头沉到水底。 1.2.2 快速排序定义 快速排序也叫做分区排序,是目前应用最广泛的排序算法。它采用分治法进行排序。其基本思想是任取待排序元素序列中的某个元素(例如取第一个元素)作为基准,按照该元素的排序码大小,将整个元素序列划分为左右两个子序列;左侧子序列中所有元素的排序码都小于基准元素的排序码,右侧子序列中所有元素的排序码都大于或等于基准元素的排序码,基准元素则排在这两个子序列中间。然后分别对这两个子序列重复实行上述方法,直到所有的元素都排在相应的位置上为止。 2.开发平台 操作系统:Microsoft Windows7 开发工具:Microsoft Visual C++ 6.0 语言选择:C++高级程序语言 3.程序设计 3.1冒泡排序 void BSort(int* a, int n ,int number,int move) //冒泡排序 {//number,move用于记录关键字的比较和移动次数 int i,j,temp; int flag; for(i=1;i=n-1;i++) { flag=0; j=n; while(j=i+1) { if(a[j]a[j-1]) //a[j]与a[j-1]比较 { temp=a[j]; a[j]=a[j-1]; a[j-1]=temp; flag=1; //如果有记录交换发生,则置交换标志为1 move+=3; //关键字移动

文档评论(0)

dreamclb + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档