



下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、姓名:_ 班级:_ 学号:_-密-封 -线- 中级软件设计师问答集考试卷模拟考.试题考试时间:120分钟 考试总分:100分题号一二三四五总分分数遵守考场纪律,维护知识尊严,杜绝违纪行为,确保考试结果公正。1、阅读下列函数说明和c代码,回答下面问题。说明冒泡排序算法的基本思想是:对于无序序列(假设扫描方向为从前向后,进行升序排列),两两比较相邻数据,若反序则交换,直到没有反序为止。一般情况下,整个冒泡排序需要进行众(1kn)趟冒泡操作,冒泡排序的结束条件是在某一趟排序过程中没有进行数据交换。若数据初态为正序时,只需1趟扫描,而数据初态为反序时,需进行n-1趟扫描。在冒泡排序中,一趟扫描有可能无
2、数据交换,也有可能有一次或多次数据交换,在传统的冒泡排序算法及近年的一些改进的算法中2,3,只记录一趟扫描有无数据交换的信息,对数据交换发生的位置信息则不予处理。为了充分利用这一信息,可以在一趟全局扫描中,对每一反序数据对进行局部冒泡排序处理,称之为局部冒泡排序。局部冒泡排序的基本思想是:对于n个待排序数据组成的序列,在一趟从前向后扫描待排数据序列时,两两比较相邻数据,若反序则对后一个数据作一趟前向的局部冒泡排序,即用冒泡的排序方法把反序对的后一个数据向前排到适合的位置。扫描第对数据对,若反序,对第2个数据向前冒泡,使前两个数据成为,有序序列;扫描第二对数据对,若反序,对第3个数据向前冒泡,使
3、得前3个数据变成有序序列;扫描第i对数据对时,其前i个数据已成有序序列,若第i对数据对反序,则对第i+1个数据向前冒泡,使前i+1个数据成有序序列;依次类推,直至处理完第n-1对数据对。当扫描完第n-1对数据对后,n个待排序数据已成了有序序列,此时排序算法结束。该算法只对待排序列作局部的冒泡处理,局部冒泡算法的名称由此得来。以下为c语言设计的实现局部冒泡排序策略的算法,根据说明及算法代码回答问题1和问题2。变量说明#define n=100 /排序的数据量typedef struct /排序结点int key;info datatype;.node;node sortdatan;/待排序的数据
4、组node类型为待排序的记录(或称结点)。数组sortdata为待排序记录的全体称为一个文件。key是作为排序依据的字段,称为排序码。datatype是与具体问题有关的数据类型。下面是用c语言实现的排序函数,参数r为待排序数组,n是待排序数组的维数,finish为完成标志。算法代码void part-bubblesort (node r, intn)int=0 ;/定义向前局部冒泡排序的循环变量/暂时结点,存放交换数据node tempnode;for (int i=0;in-1;i+);if (ri.keyri+1.key)(1)while (2)tempnode=rj ;(3)rj-1=t
5、empnode ;finish=false ;(4) / end while / end if / end for / endfunction问题1阅读下列函数说明和c代码,将应填入(n)处的字句写在的对应栏内。( )2、阅读下列函数说明和c代码,回答下面问题。说明冒泡排序算法的基本思想是:对于无序序列(假设扫描方向为从前向后,进行升序排列),两两比较相邻数据,若反序则交换,直到没有反序为止。一般情况下,整个冒泡排序需要进行众(1kn)趟冒泡操作,冒泡排序的结束条件是在某一趟排序过程中没有进行数据交换。若数据初态为正序时,只需1趟扫描,而数据初态为反序时,需进行n-1趟扫描。在冒泡排序中,一趟
6、扫描有可能无数据交换,也有可能有一次或多次数据交换,在传统的冒泡排序算法及近年的一些改进的算法中2,3,只记录一趟扫描有无数据交换的信息,对数据交换发生的位置信息则不予处理。为了充分利用这一信息,可以在一趟全局扫描中,对每一反序数据对进行局部冒泡排序处理,称之为局部冒泡排序。局部冒泡排序的基本思想是:对于n个待排序数据组成的序列,在一趟从前向后扫描待排数据序列时,两两比较相邻数据,若反序则对后一个数据作一趟前向的局部冒泡排序,即用冒泡的排序方法把反序对的后一个数据向前排到适合的位置。扫描第对数据对,若反序,对第2个数据向前冒泡,使前两个数据成为,有序序列;扫描第二对数据对,若反序,对第3个数据
7、向前冒泡,使得前3个数据变成有序序列;扫描第i对数据对时,其前i个数据已成有序序列,若第i对数据对反序,则对第i+1个数据向前冒泡,使前i+1个数据成有序序列;依次类推,直至处理完第n-1对数据对。当扫描完第n-1对数据对后,n个待排序数据已成了有序序列,此时排序算法结束。该算法只对待排序列作局部的冒泡处理,局部冒泡算法的名称由此得来。以下为c语言设计的实现局部冒泡排序策略的算法,根据说明及算法代码回答问题1和问题2。变量说明#define n=100 /排序的数据量typedef struct /排序结点int key;info datatype;.node;node sortdatan;/待排序的数据组node类型为待排序的记录(或称结点)。数组sortdata为待排序记录的全体称为一个文件。key是作为排序依据的字段,称为排序码。datatype是与具体问题有关的数据类型。下面是用c语言实现的排序函数,参数r为待排序数组,n是待排序数组的维数,finish为完成标志。算法代码void part-bubblesort (node r, intn)int=0 ;/定义向前局部冒泡排序的循环变量/暂时结点,存放交换数据node tempnode;for (int i=0;in-1;i+);if (ri.keyri+1.key)(1)while (2)tempno
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 个人补偿贸易借款合同6篇
- 高校竞聘考试题目及答案
- 现场勘察报告制作流程和表格
- 文案撰写格式与排版规范
- 高考名校联考试题及答案
- 高级验光员考试题及答案
- 钢筋算量考试题及答案
- 2025年知网检索竞赛试题及答案
- 2025年机车考试软件题库及答案
- 产品需求分析与产品设计模板
- 第5章 委托-代理理论(I)(张维迎-博弈论与信息经济学)
- 《这就是中国-走向世界的中国力量》读书笔记PPT模板思维导图下载
- 口腔疾病治疗质量控制课件
- 贵州福贵康护理院装修改造工程环评报告
- 《中国居民膳食指南(2022)》解读
- 中西医结合课件梅毒详解
- DB37T 4502-2022滤水模压混凝土板现场制作质量控制规范
- 常见秋冬季传染病预防
- CRM-客户关系管理系统毕业论文
- 质量源于设计-QbD课件
- 教学第三章土壤侵蚀课件
评论
0/150
提交评论