算法设计与分析C++语言描述(陈慧南版)课后答案.docx
《算法设计与分析C++语言描述(陈慧南版)课后答案.docx》由会员分享,可在线阅读,更多相关《算法设计与分析C++语言描述(陈慧南版)课后答案.docx(16页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、精选优质文档-倾情为你奉上第一章1-3. 最大公约数为1。快1414倍。主要考虑循环次数,程序1-2的while循环体做了10次,程序1-3的while循环体做了14141次(14142-2循环)若考虑其他语句,则没有这么多,可能就601倍。第二章2-8.(1)画线语句的执行次数为。划线语句的执行次数应该理解为一格整体。(2)画线语句的执行次数为 。(3)画线语句的执行次数为 。(4)当n为奇数时画线语句的执行次数为 ,当n为偶数时画线语句的执行次数为 。 2-10.(1) 当 时,所以,可选 ,。对于,所以,。(2) 当 时,所以,可选 ,。对于,所以,。(3) 由(1)、(2)可知,取,当
2、时,有,所以。2-11. (1) 当时,所以,。可选 ,。对于,即。注意:是f(n)和g(n)的关系。(2) 当 时,所以 ,。可选 ,。对于 ,即 。(3)因为 ,。当 时,。所以,可选 ,对于,即 。第二章2-17. 证明:设,则 。 当 时,。所以,。第五章5-4. SolutionType DandC1(int left,int right)while(!Small(left,right)&leftright)int m=Divide(left,right);if(xPm) left=m+1; else return S(P) 5-7. template int SortableLis
3、t:BSearch(const T&x,int left,int right) constif (left=right)int m=(right+left)/3;if (xlm) return BSearch(x,m+1,right);else return m;return -1;第五章9 证明:因为该算法在成功搜索的情况下,关键字之间的比较次数至少为,至多为。在不成功搜索的情况下,关键字之间的比较次数至少为,至多为。所以,算法的最好、最坏情况的时间复杂度为。假定查找表中任何一个元素的概率是相等的,为,那么,不成功搜索的平均时间复杂度为,成功搜索的平均时间复杂度为。其中,是二叉判定树的内路径
4、长度,是外路径长度,并且。11.步数012345初始时11111111111211111311111411111排序结果11111步数01234567初始时55834321423358523234585332345854233458552334558排序结果233455812.(1)证明:当或或时,程序显然正确。当n=right-left+12时,程序执行下面的语句:int k=(right-left+1)/3;StoogeSort(left,right-k);StoogeSort(left+k,right);StoogeSort(left,right-k);首次递归StoogeSort(le
5、ft,right-k);时,序列的前2/3的子序列有序。当递归执行StoogeSort(left+k,right);时,使序列的后2/3的子序列有序,经过这两次递归排序,使原序列的后1/3的位置上是整个序列中较大的数,即序列后1/3的位置上数均大于前2/3的数,但此时,前2/3的序列并不一定是有序的。再次执行StoogeSort(left,right-k);使序列的前2/3有序。经过三次递归,最终使序列有序。所以,这一排序算法是正确的。(2)最坏情况发生在序列按递减次序排列。,。设,则。冒泡排序最坏时间复杂度为,队排序最坏时间复杂度为,快速排序最坏时间复杂度为。所以,该算法不如冒泡排序,堆排序
6、,快速排序。13. template select (T&x,int k)if(mn) swap(m,n);if(m+nk|k=0) coutOut Of Bounds; return false;int *p=new tempk;int mid,left=0,right=n-1,cnt=0,j=0,r=0;for(int i=0;i0)domid=(left+right)/2;if(amidbi) right=mid;else cnt=mid; break;while(leftright-1)if(aleftcnt)if(cnt0)for(j=0;jcnt;j+)tempj=ar;r+;le
7、ft=cnt;k-=cnt;elsetempj=bi;left=0;k-;elsefor(j=0;jk;j+)tempj=ar;r+;left=cnt;k-=cnt;return tempk-1;第六章1.由题可得:,所以,最优解为,最大收益为。8.第六章6-9.普里姆算法。 因为图G是一个无向连通图。 所以n-1=m=n (n-1)/2; O(n)=m=O(n2);克鲁斯卡尔对边数较少的带权图有较高的效率,而,此图边数较多,接近完全图,故选用普里姆算法。6-10. T仍是新图的最小代价生成树。 证明:假设T不是新图的最小代价生成树,T是新图的最小代价生成树,那么cost(T)cost(T)。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 算法 设计 分析 C+ 语言 描述 陈慧南版 课后 答案
限制150内