- 1、本文档共22页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
C语言(查找与排序)
查找与排序 查找与排序 查找 顺序查找 折半查找 排序 直接插入排序 简单选择排序 冒泡排序 查找 查找 根据指定的关键字查找数组中的特定元素。 常用方法 顺序查找 折半查找 顺序查找 顺序查找 适用于小型与(或)没有排序的数组。 用关键字与数组的元素依次进行比较。 平均而言,要与数组的一半元素进行比较 顺序查找 顺序查找举例(cw1009.c) 折半查找 折半查找 适用于已经排好序的数组。 用关键字与数组的中间元素比较 如果相等,则查找结束——找到 如果keymiddle,则继续在前半部分查找 如果keymiddle,则继续在后半部分查找 如果没有可查找的部分,则查找结束——没有找到 折半查找 折半查找举例(cw1010.c) 折半查找 折半查找举例 排序 排序 按特定的顺序来安排数据。 常用方法 直接插入排序 简单选择排序 冒泡排序 数据插入 问题 把一个数据插入到已排好序的有序表中,从而得到一个新的、长度增1的有序表。 数据插入 数据插入(cw1011.c) 把一个数据插入到一个有序表中。 数据插入 数据插入 续 直接插入排序 直接插入排序 直接插入排序 直接插入排序(cw1012.c) 输入任意个数,按从小到大的顺序对它们进行排序。 直接插入排序 直接插入排序 续 简单选择排序 简单选择排序 简单选择排序 简单选择排序(cw1013.c) 输入任意个数,按从小到大的顺序对它们进行排序。 简单选择排序 简单选择排序 续 冒泡排序 冒泡排序 将相邻两个数比较,把小的调到前面,大数放到后面。 冒泡排序 冒泡排序(cw1014.c) 输入任意个数,按从小到大的顺序对它们进行排序。 冒泡排序 冒泡排序 续 小结 查找与排序是两类常用的应用。 查找是根据指定的关键字查找数组中的特定元素。 顺序查找 折半查找 排序为按特定的顺序来安排数据。 直接插入排序 简单选择排序 冒泡排序 查找与排序 78 91 57 79 87 97 79 83 72 65 87 查找表 关键字 #define N 10 void main() { int list[N+1]={0,65,72,83,79,97,87,75,57,91,78}; int key,i; printf(Input search key:); scanf(%d,key); for (i=1;(list[i]!=key)(i=N);i++); if (iN) printf(Not found!); else printf(Success! The position is %d.,i); } 78 91 57 79 87 97 79 83 72 65 97 91 87 83 79 78 75 72 65 57 83 low mid high #include stdio.h #define N 10 void main() { int i, low, mid, high, key, found; int list[N+1]={0,57,65,72,75,78,79,83,87,91,97}; printf(Sorted list:\n); for (i=1;i=N;i++) printf(%-4d, list[i]); printf(\n); printf(Input search key:); scanf(%d, key); low=1; high=N; found=0; while ((low=high) (! found)) { mid=(low+high)/2; if (keylist[mid]) low=mid+1; else if (key==list[mid]) found=1; else high=mid-1; } if (found) printf(Success! The position is %d., mid); else printf(Not found!); } 考虑不要found变量 97 91 87 79 78 75 72 65 57 83 97 91 87 83 79 78 75 72 65 57 97 91 87 79 78 75 72 65 57 1.找到插入点 2.腾出位置 3.插入数据 #include stdio.h #define N 20 void main() { int i, j, x, len=9; int list[N]={57,65,72,75,78,79,87,91,97}; printf(Sorted list:\n); for (i=0;ilen;i++) printf(
您可能关注的文档
- 2016年至2017年4月宁波市专业技术人员继续教育培训网(物联网技术网上考核题目和解答).doc
- 2016年贵州省百万公众网络学习工程解答.doc
- 2016年辽宁专业技术人员创业能力建设考试卷.doc
- (2017年春季版)人教版2017七年级历史下册第三单元综合测试课件(zxls_20170508105720).ppt
- 2016年辽宁省二级建造师继续教育必修课考试卷.docx
- 2016年辽宁省丹东市中考语文解答和解析.doc
- 2016年高考全国2卷语文试卷和解答.doc
- 2016年青岛市领导干部与公务员学法考法自测题.doc
- 2016建造师实务真题和解答.doc
- 2016时政热点原创试卷分析.doc
- 第12课 大一统王朝的巩固 课件(20张ppt).pptx
- 第17课 君主立宪制的英国 课件.pptx
- 第6课 戊戌变法 课件(22张ppt).pptx
- 第三章 物态变化 第2节_熔化和凝固_课件 (共46张ppt) 人教版(2024) 八年级上册.pptx
- 第三章 物态变化 第5节_跨学科实践:探索厨房中的物态变化问题_课件 (共28张ppt) 人教版(2024) 八年级上册.pptx
- 2025年山东省中考英语一轮复习外研版九年级上册.教材核心考点精讲精练(61页,含答案).docx
- 2025年山东省中考英语一轮复习(鲁教版)教材核心讲练六年级上册(24页,含答案).docx
- 第12课近代战争与西方文化的扩张 课件(共48张ppt)1.pptx
- 第11课 西汉建立和“文景之治” 课件(共17张ppt)1.pptx
- 唱歌 跳绳课件(共15张ppt内嵌音频)人音版(简谱)(2024)音乐一年级上册第三单元 快乐的一天1.pptx
文档评论(0)