算法导论第二章.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文档。上传文档
查看更多
算法导论第二章

《算法导论》第二章----插入排序(伪代码实现、课后习题(递归版本、二分查找策略版本)) 插入排序是算导第一个分析的算法。 之前看了很多遍,一直没有把习题做了,现在好好把习题和思考题做做,锻炼自己能力,顺便用C语言实现经典算法和数据结构。 最基础的插入排序是对前n-1项数据进行反向扫描。实现很简单,运行时间也很容易的出,直接贴代码: void insertion_sort(int A[], int length) { int i, j; int key; for(j = 1; j length; j++) { key = A[j]; i = j - 1; while(i = 0 A[i] key) { A[i+1] = A[i]; i--; } A[i+1] = key; } } 练习题2.3-4要求将插入排序改写成递归过程。实现也是比较简单。 void insertion(int A[], int length){ if(length != 1){ int key = A[length-1]; int i = length-2; while(i = 0 A[i] key){ A[i+1] = A[i]; i--; } A[i+1] = key; } } void insertion_sort(int A[], int length){ if(length 1){ insertion_sort(A, length-1); insertion(A, length); } } 练习2.3-6要求将最基础版本中的线性查找策略改成二分查找。 int binary_search(int A[], int key, int end){ int i = 0; int j = end; int m; while(i j){ m = (i + j) / 2; if(key A[m]){ i = m + 1; } else{ j = m; } } if(A[i] = key) return i; else return i + 1; } void insertion_sort(int A[], int length){ int i, j; int key; int pos; for(j = 1; j length; j++) { key = A[j]; pos = binary_search(A, key, j-1); for(i = j-1; i = pos; i--) A[i+1] = A[i]; A[pos] = key; } } 算法导论第二章习题答案 摘自:/blog/1328678 2.1插入排序 2.1-1 以图2-2为模型,说明INSERTION-SORT在数组A=31,41,59,26,41,58上的执行过程。 31 41 59 26 41 58 31 41 59 26 41 58 31 41 59 26 41 58 26 31 41 59 41 58 26 31 41 41 59 58 26 31 41 41 58 59 注:红色表示要准备插入的数,蓝色表示与红色数字比较过的数。 2.1-2 重写过程INSERTION-SORT,使之按非升序(而不是按非降序)排序。 伪代码如下: INSERTION-SORT(A) for j←to length[A] do key←A[J] i←j-1 while i0 and A[i]key do A[i+1]←A[i] i←i-1 A[i+1]←key 2.1-3 查找问题: 输入:一列数A={a1, a2, ...an}和值v。 输出:下标i,使

文档评论(0)

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

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

1亿VIP精品文档

相关文档