《[工学]第12章-缩小规模算法.ppt》由会员分享,可在线阅读,更多相关《[工学]第12章-缩小规模算法.ppt(39页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、电子工程学院电子工程学院电子工程学院电子工程学院第第12章章 缩小规模算法缩小规模算法3/5/20231电子工程学院电子工程学院电子工程学院电子工程学院上一页下一页回主目录第第12章章 缩小规模算法缩小规模算法1.1.二分搜索技术二分搜索技术2.2.归并排序归并排序3.3.快速排序快速排序4.4.习题习题3/5/20232电子工程学院电子工程学院电子工程学院电子工程学院上一页下一页回主目录二分搜索技术(二分查找、折半查找)二分搜索技术(二分查找、折半查找)n要求线性表是顺序存储结构的有序表。要求线性表是顺序存储结构的有序表。nn n个记录个记录R0R0Rn-1Rn-1按关键字按关键字keyke
2、y递增递增有序有序,在在n n个记录中找出关键字的值为个记录中找出关键字的值为x x的的记录。记录。3/5/20233电子工程学院电子工程学院电子工程学院电子工程学院上一页下一页回主目录n算法的基本思想:算法的基本思想:算法的基本思想:算法的基本思想:(1 1)先求位于查找区间正中的记录的下标)先求位于查找区间正中的记录的下标)先求位于查找区间正中的记录的下标)先求位于查找区间正中的记录的下标midmid:mid=(low+high)/2mid=(low+high)/2 (2 2)用其关键字与给定值用其关键字与给定值用其关键字与给定值用其关键字与给定值x x x x比较比较比较比较:vv 如果
3、如果如果如果 x=x=Rmid.keyRmid.key,则查找成功,返回,则查找成功,返回,则查找成功,返回,则查找成功,返回midmid值值值值vv 如如如如果果果果 x x Rmid.keyRmid.key,则则则则在在在在右右右右区区区区间间间间继继继继续续续续查查查查找找找找,置置置置low=mid+1low=mid+1 (3)(3)重重重重复复复复计计计计算算算算mid mid 以以以以及及及及Rmid.keyRmid.key与与与与x x比比比比较较较较,每每每每比比比比较较较较一一一一次次次次,查查查查找找找找区区区区间间间间缩缩缩缩小小小小一一一一半半半半。当当当当lowhig
4、hlowhigh时时时时,表表表表明明明明查查查查找找找找不成功,查找结束,返回不成功,查找结束,返回不成功,查找结束,返回不成功,查找结束,返回-1-1。3/5/20234电子工程学院电子工程学院电子工程学院电子工程学院上一页下一页回主目录查找成功的例子查找成功的例子 查找失败的例子查找失败的例子3/5/20235电子工程学院电子工程学院电子工程学院电子工程学院上一页下一页回主目录 n n折半查找算折半查找算折半查找算折半查找算法法法法intintintint BinSearch(DateTypeBinSearch(DateTypeBinSearch(DateTypeBinSearch(Da
5、teType R,R,R,R,KeyTypeKeyTypeKeyTypeKeyType x)x)x)x)intintintint low,high,midlow,high,midlow,high,midlow,high,mid;/low/low/low/low、highhighhighhigh表示当前查找区间的下界、上界表示当前查找区间的下界、上界表示当前查找区间的下界、上界表示当前查找区间的下界、上界 low=0;high=n-1;low=0;high=n-1;low=0;high=n-1;low=0;high=n-1;/设置查找区间下界、上界的初值设置查找区间下界、上界的初值设置查找区间下
6、界、上界的初值设置查找区间下界、上界的初值 while(low=high)while(low=high)while(low=high)while(low=high)/当前查找区间非空当前查找区间非空当前查找区间非空当前查找区间非空 mid=(low+high)/2;mid=(low+high)/2;mid=(low+high)/2;mid=(low+high)/2;/取当前查找区间的中点取当前查找区间的中点取当前查找区间的中点取当前查找区间的中点 if(x=if(x=if(x=if(x=Rmid.keyRmid.keyRmid.keyRmid.key)return mid;)return mi
7、d;)return mid;)return mid;/查找成功,返回查找成功,返回查找成功,返回查找成功,返回 else else else else if(xif(xif(xif(x Rmid.keyRmid.keyRmid.keyRmid.key)high=mid-1;)high=mid-1;)high=mid-1;)high=mid-1;/在左区间查找在左区间查找在左区间查找在左区间查找 else low=mid+1;else low=mid+1;else low=mid+1;else low=mid+1;/在右区间查找在右区间查找在右区间查找在右区间查找 return-1;return
8、-1;return-1;return-1;/查找失败查找失败查找失败查找失败 3/5/20236电子工程学院电子工程学院电子工程学院电子工程学院上一页下一页回主目录n对于有序序列:对于有序序列:对于有序序列:对于有序序列:-1-1-1-1、0 0 0 0、1 1 1 1、3 3 3 3、4 4 4 4、6 6 6 6、8 8 8 8、10101010、12121212,折半查找判定树:折半查找判定树:折半查找判定树:折半查找判定树:vv树中每个圆形结点表示一个树中每个圆形结点表示一个树中每个圆形结点表示一个树中每个圆形结点表示一个记录,记录,记录,记录,结点的位序是该记录结点的位序是该记录结点
9、的位序是该记录结点的位序是该记录在表中的位置在表中的位置在表中的位置在表中的位置。所有结点的。所有结点的。所有结点的。所有结点的空指针域相当于指向一个方空指针域相当于指向一个方空指针域相当于指向一个方空指针域相当于指向一个方形结点,称为外部结点。形结点,称为外部结点。形结点,称为外部结点。形结点,称为外部结点。vv用当前查找区间的中间位置用当前查找区间的中间位置用当前查找区间的中间位置用当前查找区间的中间位置上的记录作为根,左区间和上的记录作为根,左区间和上的记录作为根,左区间和上的记录作为根,左区间和右区间中的记录分别作为根右区间中的记录分别作为根右区间中的记录分别作为根右区间中的记录分别作
10、为根的左、右子树。的左、右子树。的左、右子树。的左、右子树。vv不妨设结点总数不妨设结点总数不妨设结点总数不妨设结点总数 n n n n=2=2=2=2h h h h-1-1-1-1,则描述折半查找的判定树是高度为,则描述折半查找的判定树是高度为,则描述折半查找的判定树是高度为,则描述折半查找的判定树是高度为 h h h h 的满二叉树。的满二叉树。的满二叉树。的满二叉树。2 2 2 2h h h h =n n n n+1+1+1+1,h h h h=log=log=log=log2 2 2 2(n n n n+1)+1)+1)+1)。深度。深度。深度。深度h h h h不计外部结点。不计外部
11、结点。不计外部结点。不计外部结点。vv 第第第第1 1 1 1层结点有层结点有层结点有层结点有1 1 1 1个,查找第个,查找第个,查找第个,查找第1 1 1 1层结点要比较层结点要比较层结点要比较层结点要比较1 1 1 1次;第次;第次;第次;第2 2 2 2层结点有层结点有层结点有层结点有2 2 2 2个,个,个,个,查找第查找第查找第查找第2 2 2 2层结点要比较层结点要比较层结点要比较层结点要比较2 2 2 2次;次;次;次;。查找成功,最多比较查找成功,最多比较查找成功,最多比较查找成功,最多比较h h h h次次次次。时间复。时间复。时间复。时间复杂度为杂度为杂度为杂度为O(lo
12、gO(logO(logO(log2 2 2 2n)n)n)n)3/5/20237电子工程学院电子工程学院电子工程学院电子工程学院上一页下一页回主目录n对于有序序列:对于有序序列:对于有序序列:对于有序序列:-1-1-1-1、0 0 0 0、1 1 1 1、3 3 3 3、4 4 4 4、6 6 6 6、8 8 8 8、10101010、12121212,描述折半查找过程的判定树及查找描述折半查找过程的判定树及查找描述折半查找过程的判定树及查找描述折半查找过程的判定树及查找6 6 6 6和和和和5 5 5 5的过程:的过程:的过程:的过程:查找成功的情形查找成功的情形 查找不成功的情形查找不成功
13、的情形vv查找成功的过程就是走了一条查找成功的过程就是走了一条查找成功的过程就是走了一条查找成功的过程就是走了一条从根结点到该结点的路径从根结点到该结点的路径从根结点到该结点的路径从根结点到该结点的路径,经历,经历,经历,经历比较关键字的次数恰为该结点在树中的层数比较关键字的次数恰为该结点在树中的层数比较关键字的次数恰为该结点在树中的层数比较关键字的次数恰为该结点在树中的层数。vv查找不成功的过程是一条查找不成功的过程是一条查找不成功的过程是一条查找不成功的过程是一条从根结点到外部结点的路径从根结点到外部结点的路径从根结点到外部结点的路径从根结点到外部结点的路径,所需的,所需的,所需的,所需的
14、关键字比较次数是该路径上内部结点的总数关键字比较次数是该路径上内部结点的总数关键字比较次数是该路径上内部结点的总数关键字比较次数是该路径上内部结点的总数。3/5/20238电子工程学院电子工程学院电子工程学院电子工程学院上一页下一页回主目录归并排序归并排序n算法思想算法思想算法思想算法思想假设初始表含有假设初始表含有n n个记录,则可看成是个记录,则可看成是n n个有序的子表,个有序的子表,每个子表的长度为每个子表的长度为1 1,然后两两归并,得到,然后两两归并,得到 n/2n/2 个长度个长度为为2 2或或1 1的有序子表,再两两归并,的有序子表,再两两归并,如此重复,直如此重复,直至得到一
15、个长度为至得到一个长度为n n的有序子表为止。的有序子表为止。n归并的过程归并的过程归并的过程归并的过程 将两个有序子表合并为一个有序子表的过程类似于玩将两个有序子表合并为一个有序子表的过程类似于玩扑克牌:假设桌上有两堆面朝上的牌,最小的排在上扑克牌:假设桌上有两堆面朝上的牌,最小的排在上面,现要将这两堆牌(看作输入)合并成一堆有序的面,现要将这两堆牌(看作输入)合并成一堆有序的牌(看作输出)。基本步骤是比较两输入堆顶上的两牌(看作输出)。基本步骤是比较两输入堆顶上的两张牌,取出较小的那张牌将它面朝下放到输出堆中。张牌,取出较小的那张牌将它面朝下放到输出堆中。重复这一步骤,直至某一输入堆为空,
16、这是将另一输重复这一步骤,直至某一输入堆为空,这是将另一输入堆中剩余的牌面朝下全部放入到输出堆中即可。如入堆中剩余的牌面朝下全部放入到输出堆中即可。如图所示:图所示:3/5/20239电子工程学院电子工程学院电子工程学院电子工程学院上一页下一页回主目录n n设两个有序子表(相当于输入堆)放在同一向量中相设两个有序子表(相当于输入堆)放在同一向量中相设两个有序子表(相当于输入堆)放在同一向量中相设两个有序子表(相当于输入堆)放在同一向量中相邻的位置上:邻的位置上:邻的位置上:邻的位置上:Rlow.mid,Rmid+1.highRlow.mid,Rmid+1.highRlow.mid,Rmid+1
17、.highRlow.mid,Rmid+1.high,先将它,先将它,先将它,先将它们合并到一个局部的暂存变量们合并到一个局部的暂存变量们合并到一个局部的暂存变量们合并到一个局部的暂存变量R1R1R1R1(相当于输出堆)中,(相当于输出堆)中,(相当于输出堆)中,(相当于输出堆)中,待合并完成后将待合并完成后将待合并完成后将待合并完成后将R1R1R1R1复制回复制回复制回复制回Rlow.highRlow.highRlow.highRlow.high 中。中。中。中。R Ri ji jlow highlow highk kR1R1low mid mid+low mid mid+1 1 high h
18、igh说明:加说明:加“*”区分两个区分两个25253/5/202310电子工程学院电子工程学院电子工程学院电子工程学院上一页下一页回主目录 二路归并算法(二路归并算法(MergeSortMergeSort)调用)调用一趟归并算法(一趟归并算法(MergePassMergePass),一),一趟归并算法(趟归并算法(MergePassMergePass)调用归)调用归并算法(并算法(MergeMerge)。)。3/5/202311电子工程学院电子工程学院电子工程学院电子工程学院上一页下一页回主目录n归并算法归并算法归并算法归并算法void void void void MERGE(rectyp
19、eMERGE(rectypeMERGE(rectypeMERGE(rectype R,intR,intR,intR,int low,intlow,intlow,intlow,int mid,intmid,intmid,intmid,int high)high)high)high)/*/*/*/*Rlow.midRlow.midRlow.midRlow.mid 与与与与Rmid+1.highRmid+1.highRmid+1.highRmid+1.high是两个有序子表,结果为一个有序子表是两个有序子表,结果为一个有序子表是两个有序子表,结果为一个有序子表是两个有序子表,结果为一个有序子表Rlo
20、w.highRlow.highRlow.highRlow.high*/*/*/*/intintintint i=i=i=i=low,jlow,jlow,jlow,j=mid+1,k=0;=mid+1,k=0;=mid+1,k=0;=mid+1,k=0;rectyperectyperectyperectype*R1=(*R1=(*R1=(*R1=(rectyperectyperectyperectype*)malloc(high-low+1)*)malloc(high-low+1)*)malloc(high-low+1)*)malloc(high-low+1)*sizeof(rectypesiz
21、eof(rectypesizeof(rectypesizeof(rectype););););if(!R1)if(!R1)if(!R1)if(!R1)printfprintfprintfprintf(“申请空间不成功申请空间不成功申请空间不成功申请空间不成功”);exit(0););exit(0););exit(0););exit(0);while(i=mid)&(j=high)while(i=mid)&(j=high)while(i=mid)&(j=high)while(i=mid)&(j=high)if(Ri.keyif(Ri.keyif(Ri.keyif(Ri.key=Rj.keyRj.
22、keyRj.keyRj.key)R1k+=)R1k+=)R1k+=)R1k+=RiRiRiRi+;+;+;+;else R1k+=else R1k+=else R1k+=else R1k+=RjRjRjRj+;+;+;+;/取小者复制到取小者复制到取小者复制到取小者复制到R1kR1kR1kR1k while(iwhile(iwhile(iwhile(i=mid)R1k+=mid)R1k+=mid)R1k+=mid)R1k+=RiRiRiRi+;+;+;+;/复制第一个子表的剩余记录复制第一个子表的剩余记录复制第一个子表的剩余记录复制第一个子表的剩余记录 while(jwhile(jwhile(
23、jwhile(j=high)R1k+=high)R1k+=high)R1k+=high)R1k+=RjRjRjRj+;+;+;+;/复制第二个子表的剩余记录复制第二个子表的剩余记录复制第二个子表的剩余记录复制第二个子表的剩余记录 for(kfor(kfor(kfor(k=0,i=0,i=0,i=0,i=low;ilow;ilow;ilow;i=high;k+,ihigh;k+,ihigh;k+,ihigh;k+,i+)+)+)+)RiRiRiRi=R1k;=R1k;=R1k;=R1k;/归并完成后将结果复制回归并完成后将结果复制回归并完成后将结果复制回归并完成后将结果复制回Rlow.highR
24、low.highRlow.highRlow.high 3/5/202312电子工程学院电子工程学院电子工程学院电子工程学院上一页下一页回主目录n二路归并排序二路归并排序 第第1 1趟归并排序时,将趟归并排序时,将R1.nR1.n看成是看成是 n n 个个长度为长度为 1 1 的有序子序列的有序子序列 (归并项归并项),先做两两,先做两两归并,得到归并,得到 n n/2/2 个长度为个长度为 2 2 的归并项的归并项 (如果如果 n n 为奇数,则最后一个有序子序列的长为奇数,则最后一个有序子序列的长度为度为1)1);再做两两归并,;再做两两归并,如此重复,最后,如此重复,最后得到一个长度为得到
25、一个长度为 n n 的有序序列。的有序序列。3/5/202313电子工程学院电子工程学院电子工程学院电子工程学院上一页下一页回主目录归并排序过程归并排序过程lenlen=1=1lenlen=2=2lenlen=4=4lenlen=8=8lenlen=16=163/5/202314电子工程学院电子工程学院电子工程学院电子工程学院上一页下一页回主目录n一趟归并一趟归并 在给出二路归并排序算法之前,必须先解决一趟在给出二路归并排序算法之前,必须先解决一趟在给出二路归并排序算法之前,必须先解决一趟在给出二路归并排序算法之前,必须先解决一趟归并问题。在某趟归并中,设各子表长度为归并问题。在某趟归并中,设
26、各子表长度为归并问题。在某趟归并中,设各子表长度为归并问题。在某趟归并中,设各子表长度为lengthlengthlengthlength(最后一个子表的长度可能小于(最后一个子表的长度可能小于(最后一个子表的长度可能小于(最后一个子表的长度可能小于lengthlengthlengthlength),则归并前),则归并前),则归并前),则归并前R1.nR1.nR1.nR1.n中共有中共有中共有中共有 n n n n/length/length/length/length 个有序子表:个有序子表:个有序子表:个有序子表:R1.length,Rlength+1.2*length,R1.length,
27、Rlength+1.2*length,R1.length,Rlength+1.2*length,R1.length,Rlength+1.2*length,R(R(R(R(n n n n /length/length/length/length -1)*length+1.n-1)*length+1.n-1)*length+1.n-1)*length+1.n 调用归并操作将相邻的一对子表进行归并时,必须对调用归并操作将相邻的一对子表进行归并时,必须对调用归并操作将相邻的一对子表进行归并时,必须对调用归并操作将相邻的一对子表进行归并时,必须对子表的个数可能是奇数,以及最后一个子表的长度小子表的个数可
28、能是奇数,以及最后一个子表的长度小子表的个数可能是奇数,以及最后一个子表的长度小子表的个数可能是奇数,以及最后一个子表的长度小于于于于lehgthlehgthlehgthlehgth这两种特殊情况进行特殊处理:若子表的个这两种特殊情况进行特殊处理:若子表的个这两种特殊情况进行特殊处理:若子表的个这两种特殊情况进行特殊处理:若子表的个数为奇数,则最后一个子表无须和其它子表归并(即数为奇数,则最后一个子表无须和其它子表归并(即数为奇数,则最后一个子表无须和其它子表归并(即数为奇数,则最后一个子表无须和其它子表归并(即本趟轮空);若子表的个数为偶数,则要注意最后一本趟轮空);若子表的个数为偶数,则要
29、注意最后一本趟轮空);若子表的个数为偶数,则要注意最后一本趟轮空);若子表的个数为偶数,则要注意最后一对子表中的后一个子表的区间上界是对子表中的后一个子表的区间上界是对子表中的后一个子表的区间上界是对子表中的后一个子表的区间上界是n n n n。3/5/202315电子工程学院电子工程学院电子工程学院电子工程学院上一页下一页回主目录n一趟归并算法一趟归并算法一趟归并算法一趟归并算法void void void void MERGEPASS(rectypeMERGEPASS(rectypeMERGEPASS(rectypeMERGEPASS(rectype R,R,R,R,intintintin
30、t length)length)length)length)/对对对对R1.nR1.nR1.nR1.n做一趟归并,做一趟归并,做一趟归并,做一趟归并,lengthlengthlengthlength是本趟归并的有序子表的长度是本趟归并的有序子表的长度是本趟归并的有序子表的长度是本趟归并的有序子表的长度 intintintint i,ji,ji,ji,j;i=1;i=1;i=1;i=1;/i/i/i/i指向第一对子表的起始点指向第一对子表的起始点指向第一对子表的起始点指向第一对子表的起始点 while(i+2while(i+2while(i+2while(i+2 lengthlengthleng
31、thlength 1=n);1=n);1=n);1=n);/归并长度为归并长度为归并长度为归并长度为lengthlengthlengthlength的两个子的两个子的两个子的两个子表表表表 MERGE(R,i,i+length MERGE(R,i,i+length MERGE(R,i,i+length MERGE(R,i,i+length 1,i+21,i+21,i+21,i+2 lengthlengthlengthlength 1);1);1);1);i=i+2 i=i+2 i=i+2 i=i+2 length;length;length;length;/i/i/i/i指向下一对子表的起始点
32、指向下一对子表的起始点指向下一对子表的起始点指向下一对子表的起始点 if(i+lengthif(i+lengthif(i+lengthif(i+length 1)n)1)n)1)n)1)n)/剩下两个子表,其中后一个长度小于剩下两个子表,其中后一个长度小于剩下两个子表,其中后一个长度小于剩下两个子表,其中后一个长度小于lengthlengthlengthlength MERGE(R,R1,i,i+length MERGE(R,R1,i,i+length MERGE(R,R1,i,i+length MERGE(R,R1,i,i+length 1,n);1,n);1,n);1,n);/归并最后两个
33、子表归并最后两个子表归并最后两个子表归并最后两个子表 /若若若若inininin且且且且i+length-1ni+length-1ni+length-1ni+length-1n时,子表个数为奇数,无须归并时,子表个数为奇数,无须归并时,子表个数为奇数,无须归并时,子表个数为奇数,无须归并 3/5/202316电子工程学院电子工程学院电子工程学院电子工程学院上一页下一页回主目录n二路归并算法二路归并算法二路归并算法二路归并算法 二路归并排序须调用二路归并排序须调用二路归并排序须调用二路归并排序须调用“一趟归并一趟归并一趟归并一趟归并”对对对对R1.nR1.nR1.nR1.n进行进行进行进行 lo
34、glogloglog2 2 2 2n n n n 趟归并,每趟归并后,有序子表的长度均扩大趟归并,每趟归并后,有序子表的长度均扩大趟归并,每趟归并后,有序子表的长度均扩大趟归并,每趟归并后,有序子表的长度均扩大一倍(最后一个可能例外)。其算法如下:一倍(最后一个可能例外)。其算法如下:一倍(最后一个可能例外)。其算法如下:一倍(最后一个可能例外)。其算法如下:void void void void MERGESORT(rectypeMERGESORT(rectypeMERGESORT(rectypeMERGESORT(rectype R)/R)/R)/R)/对对对对R R R R进行二路归进行
35、二路归进行二路归进行二路归并排序并排序并排序并排序 intintintint length;length;length;length;length=1;length=1;length=1;length=1;while(lengthn)while(lengthn)while(lengthn)while(lengthn)/进行进行进行进行 loglogloglog2 2 2 2n n n n 趟归并趟归并趟归并趟归并 MERGEPASS(R,length);MERGEPASS(R,length);MERGEPASS(R,length);MERGEPASS(R,length);length=2 le
36、ngth=2 length=2 length=2 length;length;length;length;/有序子表长度有序子表长度有序子表长度有序子表长度n n n n是结束循环是结束循环是结束循环是结束循环 3/5/202317电子工程学院电子工程学院电子工程学院电子工程学院上一页下一页回主目录n归并排序算法分析归并排序算法分析长长长长度度度度为为为为n n n n的的的的表表表表,共共共共进进进进行行行行 loglogloglog2 2 2 2n n n n 趟趟趟趟归归归归并并并并,每每每每趟趟趟趟归归归归并并并并的的的的时时时时间间间间为为为为O(nO(nO(nO(n),所以归并排序
37、的时间复杂度为,所以归并排序的时间复杂度为,所以归并排序的时间复杂度为,所以归并排序的时间复杂度为O(nlogO(nlogO(nlogO(nlog2 2 2 2n)n)n)n)。归归归归并并并并排排排排序序序序占占占占用用用用附附附附加加加加存存存存储储储储较较较较多多多多,需需需需要要要要另另另另外外外外一一一一个个个个与与与与原原原原待待待待排排排排序序序序记记记记录录录录数数数数组组组组同同同同样样样样大大大大小小小小的的的的辅辅辅辅助助助助数数数数组组组组,空空空空间间间间复复复复杂杂杂杂度为度为度为度为O(nO(nO(nO(n)。这是归并排序算法的缺点。这是归并排序算法的缺点。这是归
38、并排序算法的缺点。这是归并排序算法的缺点。归并排序是一个稳定的排序方法。归并排序是一个稳定的排序方法。归并排序是一个稳定的排序方法。归并排序是一个稳定的排序方法。3/5/202318电子工程学院电子工程学院电子工程学院电子工程学院上一页下一页回主目录快速排序快速排序n n快速排序方法的基本思想是任取待排序记录序列中的快速排序方法的基本思想是任取待排序记录序列中的快速排序方法的基本思想是任取待排序记录序列中的快速排序方法的基本思想是任取待排序记录序列中的某个记录某个记录某个记录某个记录 (例如取第一个记录例如取第一个记录例如取第一个记录例如取第一个记录)作为基准,一趟划分后作为基准,一趟划分后作
39、为基准,一趟划分后作为基准,一趟划分后以该记录的关键字作为枢轴以该记录的关键字作为枢轴以该记录的关键字作为枢轴以该记录的关键字作为枢轴(pivot)(pivot),将整个记录序列,将整个记录序列,将整个记录序列,将整个记录序列划分为左右两个无序子序列:划分为左右两个无序子序列:划分为左右两个无序子序列:划分为左右两个无序子序列:uu 左侧子序列中所有记录的关键字都小于或等于枢轴左侧子序列中所有记录的关键字都小于或等于枢轴左侧子序列中所有记录的关键字都小于或等于枢轴左侧子序列中所有记录的关键字都小于或等于枢轴记录的关键字记录的关键字记录的关键字记录的关键字uu 右侧子序列中所有记录的关键字都大于
40、枢轴记录的右侧子序列中所有记录的关键字都大于枢轴记录的右侧子序列中所有记录的关键字都大于枢轴记录的右侧子序列中所有记录的关键字都大于枢轴记录的关键字关键字关键字关键字n n枢轴记录则排在这两个子序列中间枢轴记录则排在这两个子序列中间枢轴记录则排在这两个子序列中间枢轴记录则排在这两个子序列中间(这也是该记录最终这也是该记录最终这也是该记录最终这也是该记录最终应安放的位置应安放的位置应安放的位置应安放的位置)。n n然后分别对这两个子序列重复施行上述方法,直到所然后分别对这两个子序列重复施行上述方法,直到所然后分别对这两个子序列重复施行上述方法,直到所然后分别对这两个子序列重复施行上述方法,直到所
41、有的记录都按关键字有序排在相应位置上为止。有的记录都按关键字有序排在相应位置上为止。有的记录都按关键字有序排在相应位置上为止。有的记录都按关键字有序排在相应位置上为止。3/5/202319电子工程学院电子工程学院电子工程学院电子工程学院上一页下一页回主目录n快速排序算法快速排序算法快速排序算法快速排序算法采采采采 用用用用 快快快快 速速速速 排排排排 序序序序 方方方方 法法法法 对对对对 n n n n个个个个 记记记记 录录录录 排排排排 序序序序,只只只只 须须须须 调调调调 用用用用QuickSort(R,1,n)QuickSort(R,1,n)QuickSort(R,1,n)Qui
42、ckSort(R,1,n),即即即即可可可可完完完完成成成成对对对对R1.nR1.nR1.nR1.n的的的的排排排排序序序序。快快快快速速速速排排排排序序序序算法如下:算法如下:算法如下:算法如下:void void void void QUICKSORT(rectypeQUICKSORT(rectypeQUICKSORT(rectypeQUICKSORT(rectype R,R,R,R,intintintint s1,int t1);s1,int t1);s1,int t1);s1,int t1);/对对对对RsRsRsRs1 1 1 1 到到到到RtRtRtRt1 1 1 1 做快速排序做
43、快速排序做快速排序做快速排序 intintintint i;i;i;i;if(s1t1)if(s1t1)if(s1t1)if(s1=temp.key)&(itemp.key)&(itemp.key)&(itemp.key)&(ij)j)j)j)j j j j;/从从从从右右右右向向向向左左左左扫扫扫扫描描描描,查查查查找找找找第第第第一一一一个个个个关关关关键键键键字字字字小小小小于于于于temp.keytemp.keytemp.keytemp.key的的的的记记记记录录录录 if(iif(iif(iif(ij)j)j)j)RiRiRiRi+=+=+=+=RjRjRjRj;/将将将将RjRjR
44、jRj 放入放入放入放入j j j j位置,位置,位置,位置,i i i i右移右移右移右移 while(Ri.keywhile(Ri.keywhile(Ri.keywhile(Ri.key=temp.key)&(itemp.key)&(itemp.key)&(itemp.key)&(ij)j)j)j)i+;i+;i+;i+;/从左向右扫描,查找第一个关键字大于从左向右扫描,查找第一个关键字大于从左向右扫描,查找第一个关键字大于从左向右扫描,查找第一个关键字大于temp.keytemp.keytemp.keytemp.key的记录的记录的记录的记录 if(iif(iif(iif(ij)j)j)
45、length,change=TRUE;i1&change;-i)/进行进行n-1趟排序。若前一趟未发生交换,则结束排序趟排序。若前一趟未发生交换,则结束排序 change=FALSE;/设置未交换标志设置未交换标志for(int j=1;jrj+1.keyrj.key)/若不符合非递减的顺序,则进行交换若不符合非递减的顺序,则进行交换 temp=L-rj;L-rj=L-rj+1;L-rj+1=temp;change=TRUE;/设置本趟发生交换的标志设置本趟发生交换的标志 起泡排序的算法(不讲)起泡排序的算法(不讲)3/5/202327电子工程学院电子工程学院电子工程学院电子工程学院上一页下一
46、页回主目录算法分析算法分析n在对象的初始排列已经按关键字从小到大排好序时,此算法只执行一趟起泡,做 n-1 次关键字比较,不移动对象。这是最好的情形。n最坏的情形是算法执行了n-1趟起泡,第 i 趟(1 i n)做了 n-i 次关键字比较,执行了n-i 次对象交换。这样在最坏情形下总的关键字比较次数(KCN)和对象移动次数(RMN)为:3/5/202328电子工程学院电子工程学院电子工程学院电子工程学院上一页下一页回主目录 n起泡排序需要一个附加对象以实现对象值的对换。n起泡排序是一个稳定的排序方法。3/5/202329电子工程学院电子工程学院电子工程学院电子工程学院上一页下一页回主目录双向起
47、泡排序(不讲)双向起泡排序(不讲)void void dbubblesort(sequenlistdbubblesort(sequenlist r,r,intint n)n)intint i=1,j,change=1;i=1,j,change=1;sequenlistsequenlist temp;temp;while(changewhile(change)change=0;change=0;/设置本趟交换标志的初值设置本趟交换标志的初值设置本趟交换标志的初值设置本趟交换标志的初值for(jfor(j=n-i+1;j=i+1;j-)=n-i+1;j=i+1;j-)/从右向左扫描从右向左扫描从右
48、向左扫描从右向左扫描 if(rj.keyif(rj.keyrj-1.key)rj-1.key)temp=temp=rjrj;rjrj=rj-1;rj-1=temp;=rj-1;rj-1=temp;change=1;change=1;/设置本趟发生交换标志设置本趟发生交换标志设置本趟发生交换标志设置本趟发生交换标志 3/5/202330电子工程学院电子工程学院电子工程学院电子工程学院上一页下一页回主目录for(jfor(j=i+1;j=i+1;jrj+1.key)rj+1.key)temp=temp=rjrj;rjrj=rj+1;rj+1=temp;=rj+1;rj+1=temp;change=
49、1;change=1;/设置本趟发生交换标志设置本趟发生交换标志设置本趟发生交换标志设置本趟发生交换标志 for(intfor(int k=1;k=k=1;k=n;kn;k+)+)/输出本趟排序的结果输出本趟排序的结果输出本趟排序的结果输出本趟排序的结果 printf(%5d,rk.key);printf(%5d,rk.key);printf(nprintf(n););i+;i+;3/5/202331电子工程学院电子工程学院电子工程学院电子工程学院上一页下一页回主目录 选择排序的基本思想是:每一趟选择排序的基本思想是:每一趟(例如第例如第 i 趟,趟,i=1,n-1)在后面的在后面的 n-i+
50、1 个待排序对象中选个待排序对象中选出关键字最小的对象出关键字最小的对象,作为有序对象序列的第作为有序对象序列的第 i 个对象。待到第个对象。待到第 n-1 趟作完,待排序对象只剩下趟作完,待排序对象只剩下1个,就不用再选了。个,就不用再选了。选择排序选择排序(Selection Sort)(不讲)(不讲)n基本步骤为:基本步骤为:i从从1开始,直到开始,直到n-1,进行进行n-1趟趟排序,第排序,第i 趟的排序过程为:趟的排序过程为:在一组对象在一组对象rirn(i=1,2,n-1)中选择具有最小关键字的中选择具有最小关键字的对象;并和第对象;并和第 i 个对象进行交换;个对象进行交换;3/