用随机算法求第k小项_第1页
用随机算法求第k小项_第2页
用随机算法求第k小项_第3页
用随机算法求第k小项_第4页
用随机算法求第k小项_第5页
已阅读5页,还剩3页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1, 问题描述设A1,n是一个有n个数组成的无序数列,寻找其第k小元素就是将A按照非递减的顺序排列后,新序列中的第k个元素。寻找第k小元素最直接的方法就是直接将A进行排序,然后取出第k个元素,但是此类方法时间复杂度较高,至少需要(nlogn)时间,因为基本所有已学的排序方法在最坏情况下都需要这么多时间。 在第三章中老师课上教导了利用分治法求第k小元素的算法,其时间复杂度为O(n)。其基本思想如下:在分治法递归调用的每一个划分步骤中都将舍弃一定比例的元素,而在剩余元素中寻找目标。故在我的理解中这种分治法的性能主要依赖于每次递归调用能舍去的元素的比例,以及为舍弃这些元素所花费的代价。在之后的学习中,我们又接触到了随机算法,不由思考,分治法中的划分可以不可以通过随机算法来随机选择一个位置,然后根据这个位置进行舍弃序列中的元素,有没有办法改进算法。2, 随机选择算法Algorithm: RandomSelect (Alow, high, k)输入:数组Alow,.high和整数k,1 k high-low+1输出:Alowhigh中的第k小元素v random(low,high)x Av将Alowhigh分成三部分 A1a|a x /(n)case | A1 | k : return RandomSelect(A11, |A1|, k) | A1 |+| A2 | k : return x | A1 |+| A2 | k: return RandomSelect(A31,|A3|, k-|A1|-|A2|)end case该部分算法ppt与书上已经提到,其时间复杂度的期望比较次数C(n) 4n,此外每个元素与基准元素x至少比较一次。故C(n) n及nC(n)4n,故时间复杂度为(n)这部分书上与ppt上已有证明就不过多论述了3, 对以上随机算法的一种思考改进分析以上算法不难发现,其先随机选择一个位置v,然后根据v进行对元素的舍弃,所以每次舍弃不同个元素的概率是相同的,我就思考可不可以让选中舍弃较多元素的位置的概率更大,让算法有更大几率舍弃掉较多的元素。 算法的想法如下:如果随机选择一个位置的元素进行比较,每个位置的可能性是均等的,取到的数值可能最大、最小,也可能中间,如果是最大最小的情况,每次舍弃的数值就只能有一个,只有尽可能的取大小排在中间的数值,才能舍去较大的元素,故我思考,不妨选择随机选择两个位置,v,j令x=(Av+Aj)/2,然后通过x进行分组,这样取到数值为中间大小的数比取到最大最小值的可能性更高,舍弃较多数的几率更大。进而进行了优化。 理论上,选择的随机位置越多,平均后,舍弃掉较多数的可能越大,但是这就退化近似成取中值进行分治法求第k小元素的方法,丧失了随机算法的优点,将直接随机到最优解和较优解的可能性也降低了,所以我尝试取2个随机位置的方法进行优化。 并且当选择两个随机位置时,序列长度小于等于2个时,没有执行随机算法的必要 先从一个特例分析其取到各位置的理论概率大小,令n=8,其取到不同位置的概率如下表(为表示清晰,v,j位置为A进行排序后的位置) 由表格数据可以发现,此时数组划分数据x可能处于不同的位置的概率分为别为:3/64,7/64,11/64,15/64,13/64,9/64,5/64,1/64 显然舍去较多数的几率更高。改进的随机算法:Algorithm: NewSelect (Alow, high, k)输入:数组Alow,.high和整数k,1 k high-low+1输出:Alowhigh中的第k小元素If(high-low2)thenIf(k=1) then return min(Alow,Ahigh)Else return max(Alow,Ahigh)End ifelsev random(low,high)j random(low,high)x (Av+Aj)/2将Alowhigh分成三部分 A1a|a x /(n)case | A1 | k : return NewSelect(A11, |A1|, k) | A1 |+| A2 | k : return x | A1 |+| A2 | k: return NewSelect (A31,|A3|, k-|A1|-|A2|)end case end if 该算法的最坏情况与最初算法是一致的,但是其舍弃较大数的可能性应该较大,下面进行时间复杂度的理论分析4, 时间复杂度分析仿照ppt上对原算法的证明方式,证明如下(因为个人对数学公式符号用电脑表示不熟悉,而且因为证明较繁琐故用手写证明拍照如下,往老师见谅。) 由证明可知,改进后的算法的时间复杂度也是(n),虽然数量级相同,但是其前系数还是减小了。模拟仿真:实际编程,比较实际情况中原算法与改进算法的执行次数,发现其是否有改进。为使数据明显,取n值较大,当n=5000时,不同k的执行次数如表格: 当k不同时,进行数据拟合,结果如下及O(k)= -2.1nlogn -469.2logn+26.80n+11010.2706当n改变时,做出其一次关系式,改进后的算法时间复杂度绘图如下O(n)= 2.579n5, 总结通过以上的分析证明,以

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论