算法设计和分析计算题.docVIP

  1. 1、本文档共19页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
PAGE  《算法设计与分析》 排序和查找是经常遇到的问题。按照要求完成以下各题: (1)对数组A={15,29,135,18,32,1,27,25,5},用快速排序方法将其排成递减序。 解:(1)第一步:15 29 135 18 32 1 27 25 5 第二步:29 135 18 32 27 25 15 1 5 第三步:135 32 29 18 27 25 15 5 1 第四步:135 32 29 27 25 18 15 5 1 (2)请描述递减数组进行二分有哪些信誉好的足球投注网站的基本思想,并给出非递归算法。 解:基本思想:首先将待有哪些信誉好的足球投注网站元素v与数组的中间元素进行比较,如果,则在前半部分元素中有哪些信誉好的足球投注网站v;若,则有哪些信誉好的足球投注网站成功;否则在后半部分数组中有哪些信誉好的足球投注网站v。 非递归算法: 输入:递减数组A[left:right],待有哪些信誉好的足球投注网站元素v。 输出:v在A中的位置pos,或者不在A中的消息(-1)。 步骤: int BinarySearch(int A[],int left,int right,int v) { int mid; while (left=right) { mid=int((left+right)/2); if (v==A[mid]) return mid; else if (vA[mid]) right=mid-1; else left=mid+1; } return -1; } (3)给出上述算法的递归算法。 解:输入:递减数组A[left:right],待有哪些信誉好的足球投注网站元素v。 输出:v在A中的位置pos,或者不在A中的消息(-1)。 步骤:【3分】 int BinarySearch(int A[],int left,int right,int v) { int mid; if (left=right) { mid=int((left+right)/2); if (v==A[mid]) return mid; else if (vA[mid]) return BinarySearch(A,left,mid-1,v); else return BinarySearch(A,mid+1,right,v); } else return -1; } (4)使用上述算法对(1)所得到的结果有哪些信誉好的足球投注网站如下元素,并给出有哪些信誉好的足球投注网站过程:18,31,135。 解:有哪些信誉好的足球投注网站18:首先与27比较,1827,在后半部分有哪些信誉好的足球投注网站;再次与18比较,有哪些信誉好的足球投注网站到,返回5。 有哪些信誉好的足球投注网站31:首先与27比较,3127,在前半部分有哪些信誉好的足球投注网站;再次32比较,3132,在后半部分有哪些信誉好的足球投注网站,与29比较,3129,此时只有一个元素,未找到,返回-1。 有哪些信誉好的足球投注网站135:首先与27比较,13527,在前半部分有哪些信誉好的足球投注网站;再次32比较,13532,在前半部分有哪些信誉好的足球投注网站;与135比较,相同,返回0。 二、排序和查找是常用的计算机算法。按照要求完成以下各题: (1)对数组A={15,9,115,118,3,90,27,25,5},使用合并排序方法将其排成递减序。 (2)若改变二分有哪些信誉好的足球投注网站法为三分有哪些信誉好的足球投注网站法,即从一个递减序列A中寻找元素Z,先与元素比较,若,则在前面个元素中寻找Z;否则与比较,总之使余下的序列为个元素。给出该方法的伪代码描述。 (3)使用上述算法对(1)所得到的结果有哪些信誉好的足球投注网站如下元素,并给出有哪些信誉好的足球投注网站过程:118,31,25。 解:(1)第一步:15 9 115 118 3 90 27 25 5 第二步:15 9 118 115 90 3 27 25 5 第三步:118 115 15 9 90 27 25 3 5 第四步:118 115 90 27 25 15 9 3 5 第五步:118 115 90 27 25 15 9 5 3 (2)输入:递减数组A[left:right],待有哪些信誉好的足球投注网站元素v。 输出:v在A中的位置pos,或者不在A中的消息(-1)。 步骤: int BinarySearch(int A[],int left,int right,int v) { int mid; while (left=right) { first=left+(right-left+1)/3; second=left+(right-left+1)/3*2; if (v==A[first]) return first; else if (vA[first]) right=first-1; else if (v==A[second]) return second; else if (vA[second]) {left=first+1;right=second-1;} else left=secon

文档评论(0)

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

分享好文档!

1亿VIP精品文档

相关文档