线性时间选择算法.docVIP

  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文档。上传文档
查看更多
线性时间选择算法

福州大学数学与计算机科学学院 《计算机算法设计与分析》上机实验报告(1) 专业和班级 数学02班 姓名 詹小青 成绩 学号 031201206 实验名称 线性时间选择算法 实验目的 通过实验,至少掌握一种线性时间选择算法 实验任务 设计一种线性时间选择算法,证明算法的正确性并且分析它的时间复杂度。 实验步骤 1、算法设计思想(最坏情况线性时间做选择): 这种算法基本思想是保证每个数组的划分都是一个好的划分,以5为基,五数取分。利用它的思想,可以快速返回和最终中位数相差不超过2的数,这样的划分接近最优,基本每次都二分了。 2、算法基本步骤: 算法SELECT通过执行下列步骤来确定一个有n个元素的输入数组中的第i个小的元素。 1)将输入数组的n个元素划分为n/5组,每组5个元素,且至多有一个组由剩下的n mod 5个元素组成; 2)寻找n/5个组中每一组的中位数。(方法首先对每组中的元素进行插入排序,然后从排序过的序列中选出中位数); 3)对第2步中找出的n/5个中位数,递归调用SELECT找出其中位数x。(如果有偶数个中位数,根据约定,x是下中位数。) 4)利用修改过的PARTITION过程,按中位数的中位数x对输入数组进行划分。让k比划分低区的元素多1,所以x是第k小的元素,并且有n-k个元素在划分的高区; 5)如果i=k,则返回x,否则,如果ik,则在低区递归调用SELECT以找出第i小的元素,如果ik,则在高区找第(i-k)个最小元素。 3、时间复杂度分析: 图中箭头指向表示大的数值指向小的数值,所以根据图可以看出,在x的右边,每一个包含5个元素的组中至少有3个元素大于x,在x的左边,每一组中至少有3个元素小于x(保证x分割一边必定有元素存在)。 图中显示的中位数的中位数x的位置,每次选取x作为划分的好处是能够保证必定有一部分在x的一边。所以算法最坏情况的递归公式可以写成: ,使用替换法可以得出。 4、算法代码: #include iostream #include ctime using namespace std; template class Type void Swap(Type x,Type y); inline int Random(int x, int y); template class Type int Partition(Type a[],int p,int r); templateclass Type int RandomizedPartition(Type a[],int p,int r); template class Type Type RandomizedSelect(Type a[],int p,int r,int k); int main() { void SelectionSort(int a[]); int s; int a[2000]; int b[2000]; for(int i=0; i2000; i++) { a[i]=b[i]=rand()%10000; couta[i] ; } coutendl; SelectionSort(b); for(int j=0;j2000;j++) { printf(a[%d]:%d ,j+1,b[j]); } coutendl; printf(请输入要求的第几最小数:); scanf(%d,s); coutRandomizedSelect(a,0,1999,s)endl; } template class Type void Swap(Type x,Type y) { Type temp = x; x = y; y = temp; } inline int Random(int x, int y) { srand((unsigned)time(0)); int ran_num = rand() % (y - x) + x; return ran_num; } template class Type int Partition(Type a[],int p,int r) { int i = p,j = r + 1; Type x = a[p]; while(true) { while(a

文档评论(0)

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

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

1亿VIP精品文档

相关文档