C语言课件(查找和排序)课案.ppt
文本预览下载声明
查找与排序 查找与排序 查找 顺序查找 折半查找 排序 直接插入排序 简单选择排序 冒泡排序 查找 查找 根据指定的关键字查找数组中的特定元素。 常用方法 顺序查找 折半查找 顺序查找 顺序查找 适用于小型和(或)没有排序的数组。 用关键字与数组的元素依次进行比较。 平均而言,要与数组的一半元素进行比较 顺序查找 顺序查找举例(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(
显示全部