线性时间选择-angsong.docxVIP

  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文档。上传文档
查看更多
计算机算法设计与分析 题 目: 线性时间选择问题 院 (系): 数学与计算机学院 年级专业: 信息与计算科学 姓 名: 杨 松 学 号: 201210802023 指导教师: 鄢 莉 二〇一四年十一月十九日 攀枝花学院教务处制 一、实验目的: 熟悉掌握分治算法设计技术 二、实验内容: 给定线性序集中n个元素和一个整数k,1≤k≤n,要求找出这n个元素中第k小的元素。 对于线性序列集合中元素个数比较少的情况,可以先排序,再选择这n个元素中第k小的元素。但排序的时间复杂度最好是O(nlogn)。 如果能在线性时间内找到一个划分基准,使得按这个基准所划分出的2个子数组的长度都至少为原数组长度的ε倍(0ε1是某个正常数),那么就可以在最坏情况下用O(n)时间完成选择任务。 实验要求: 1、按教材所授内容要求,完成“线性时间选择问题”算法。得到一个完整正确的程序。 2、问题规模:不少于2000 3、输出最终结果。 实验设备: Windows 7系统、Visual C++ 算法分析: 将n个输入元素划分成én/5ù个组,每组5个元素,只可能有一个组不是5个元素。用任意一种排序算法,将每组中的元素排好序,并取出每组的中位数,共én/5ù个。 递归调用select( )来找出这én/5ù个元素的中位数。如果én/5ù是偶数,就找它的2个中位数中较大的一个。以这个元素作为划分基准。 设所有元素互不相同。在这种情况下,找出的基准x至少比3(n-5)/10个元素大,因为在每一组中有2个元素小于本组的中位数,而n/5个中位数中又有(n-5)/10个小于基准x。同理,基准x也至少比3(n-5)/10个元素小。而当n≥75时,3(n-5)/10≥n/4所以按此基准划分所得的2个子数组的长度都至少缩短1/4。 按照此法计算所花费时间为:T(n)=O(n) 程序源码: #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) { w

文档评论(0)

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

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

1亿VIP精品文档

相关文档