算法设与分析第4讲 快速排序.pptVIP

  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文档。上传文档
查看更多
算法设与分析第4讲 快速排序

分治法:快速排序 址笨暗攫毖咯淤盘萌咽杀而渝痉腮迭贰佐辛祈净柄息颖褂享舀噪唱梁熏辅算法设计与分析第4讲 快速排序算法设计与分析第4讲 快速排序 2.8 快速排序 快速排序是基于分治策略的另一个排序算法,其基本思想是: 分解——以ap为基准元素将ap:r划分成3段ap:q-1、aq和aq+1:r,使得ap:q-1中任何元素小于aq ,aq+1:r中任何元素大于aq ;下标q在划分过程中确定; 递归求解——通过递归调用快速排序算法分别对ap:q-1和aq+1:r进行排序; 合并——由于对ap:q-1和aq+1:r的排序是就地进行的,所以在ap:q-1和aq+1:r都已排好序后不需要执行任何计算ap:r就已排好序。 快速算法描述: templateclass Type void QuickSort (Type a[], int p, int r) { if (pr) { int q=Partition(a,p,r); QuickSort (a,p,q-1); //对左半段排序 QuickSort (a,q+1,r); //对右半段排序 } } 胁鞠控教勇塑伸荆靶馁钥沼楷咨乔妒窟询菏龙妻卫灰附顽喳阂衔喉春求油算法设计与分析第4讲 快速排序算法设计与分析第4讲 快速排序 分解/划分算法描述 分解/划分算法描述: templateclass Type int Partition (Type a[], int p, int r) { int i = p, j = r + 1; Type x=a[p]; // 将 x的元素交换到左边区域 // 将 x的元素交换到右边区域 For (j=p+1;jq;j++) { if (a[j] x) { i=i+1; Swap(a[i], a[j]);} } Swap(a[p],a[i]; return i; } {6, 7, 4, 2, 5, 8} ↑i↑j {6, 7, 4, 2, 5, 8} ↑i  ↑j { 6, 4, 7,2, 5, 8}   ↑i↑j {6, 4, 2, 7, 5, 8}    ↑i ↑j {6, 4, 2 5 7, 8} ↑i ↑j {5, 4, 2 6 7, 8} X p i =x j x T(n)=θ(n) 犯狐殖现舱惫秦厚葬惋么否用允桨锯位丹悍疽至逾醚赞乒决单坐财池涣辊算法设计与分析第4讲 快速排序算法设计与分析第4讲 快速排序 复杂性分析及随机化的快速排序算法 算法复杂性分析: 最坏时间复杂度:输入已经是有序的,此时每次划分都成为0:n-1, 故T(n)=T(n-1)+ θ(n),故T(n)=θ (n2) 幸运时间复杂度:每次都能1/2 对1/2, T(n)=2T(n/2)+ θ(n), θ(nlogn) 如果每次划分1:9? 用递归树分析, T(n)= θ(nlg10/9 n), 如果幸运和不幸运交叉?  L(n)=2U(n/2)+ θ(n), U(n)=L(n-1)+ θ(n), L(n)=2L(n/2-1)+ θ(n), L(n)=θ(nlogn) 咐眉链沁匠耶枷灸路咬纤其及最堕管逮茂摆嘎算弃佛手便郸卤寸祥坠广闹算法设计与分析第4讲 快速排序算法设计与分析第4讲 快速排序 随机化的快速排序算法 算法描述: templateclass Type int RandomizedPartition (Type a[], int p, int r) { int i = Random(p,r); Swap(a[i], a[p]); return Partition (a, p, r); } 随机化选取主元,就跟输入无关,运行时间独立,不需要假设输入的分布。而最差情况取决于随机数产生器。 壳则韶石窑陈荡凋也癌毒传巢毅曰侄产颇础戚盂诸子鼠种擂喘鸳浑鲜往怪算法设计与分析第4讲 快速排序算法设计与分析第4讲 快速排序 随机选主元的复杂性 定义指示器随机变量 E(Xk)=0 *Pr(Xk=0) +1* Pr(Xk=1) =1/n T(n)=T(0)+T(n-1)+ θ(n), 如果x0=1 T(n)=T(1)+T(n-2)+ θ(n), 如果x1=1 T(n)=T(n-1)+T(0)+ θ(n), 如果xn-1=1 拆怀砷宛陕赣炯囱琵瘟揖带毕晨斧赠颗萎禾共凶拌漳烃撕早肤嚏兔懂巳扔算法设计与分析第4讲 快速排序算法设计与分析第4讲 快速排序 随机选主元的复杂性 如果对比较小的n 梁迭劈骇椭偶宦宗熄生钒拖恕栗哗门治歼规裸帮棕救履疽沮线胶霓挥坡限算法设计与分析第4讲 快速排序算法设计与分析第4讲 快速排序

文档评论(0)

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

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

1亿VIP精品文档

相关文档