算法设计与分析C++语言描述(陈慧南版)课后答案(7页).doc
《算法设计与分析C++语言描述(陈慧南版)课后答案(7页).doc》由会员分享,可在线阅读,更多相关《算法设计与分析C++语言描述(陈慧南版)课后答案(7页).doc(7页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、-第 1 页算法设计与分析C+语言描述(陈慧南版)课后答案-第 2 页第一章1-3.最大公约数为 1。快 1414 倍。主要考虑循环次数,程序 1-2 的 while 循环体做了 10 次,程序 1-3 的 while 循环体做了 14141 次(14142-2循环)若考虑其他语句,则没有这么多,可能就 601 倍。第二章2-8.(1)画线语句的执行次数为logn。(log)n。划线语句的执行次数应该理解为一格整体。(2)画线语句的执行次数为111(1)(2)16jniijkn nn。3()n。(3)画线语句的执行次数为n。()n。(4)当 n 为奇数时画线语句的执行次数为(1)(3)4nn,
2、当 n 为偶数时画线语句的执行次数为2(2)4n。2()n。2-10.(1)当1n时,225825nnn,所 以,可 选5c,01n。对 于0nn,22()5825f nnnn,所以,22582()nnn。(2)当8n 时,2222582524nnnnn,所以,可选4c,08n。对于0nn,22()5824f nnnn,所以,22582()nnn。(3)由(1)、(2)可知,取14c,25c,08n,当0nn时,有22212582c nnnc n,所以22582()nnn。2-11.(1)当3n 时,3loglognnn,所以()20log21f nnnn,3()log2g nnnn。可选21
3、2c,03n。对于0nn,()()f ncg n,即()()f ng n。注意:是 f(n)和 g(n)的关系。(2)当4n时,2loglognnn,所以22()/logf nnnn,22()logg nnnn。可选1c,04n。对于0nn,2()()f nncg n,即()()f ng n。(3)因为loglog(log)()(log)nnf nnn,()/loglog 2ng nnnn。当4n时,log(log)()nf nnn,()log 2ng nnn。所以,可选1c,04n,对于0nn,()()f ncg n,即()()f ng n。第二章2-17.证明:设2in,则login。-第
4、 3 页当2n时,22 logT nnn。所以,2logT nnn。第五章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 SortableList:BSearch(const T&x,int left,int right)constif(left=right)int m=(right+left)/3;if(xlm)return BSearch
5、(x,m+1,right);else return m;return-1;第五章9证明:因为该算法在成功搜索的情况下,关键字之间的比较次数至少为logn,至多为log1n。在不成功搜索的情况下,关键字之间的比较次数至少为log1n,至多为log2n。所以,算法的最好、最坏情况的时间复杂度为logn。假定查找表中任何一个元素的概率是相等的,为1n,那么,不成功搜索的平均时间复杂度为 log1uEAnnn,成功搜索的平均时间复杂度为 21logsInEnnEA nnnnn 。其中,I是二叉判定树的内路径长度,E是外路径长度,并且2EIn。11.步数012345初始时1111111111121111
6、1311111411111排序结果11111步数01234567初始时55834321423358523234585-第 4 页332345854233458552334558排序结果233455812.(1)证明:当0n 或1n 或2n 时,程序显然正确。当 n=right-left+12 时,程序执行下面的语句:int k=(right-left+1)/3;StoogeSort(left,right-k);StoogeSort(left+k,right);StoogeSort(left,right-k);首次递归 StoogeSort(left,right-k);时,序列的前 2/3 的子
7、序列有序。当递归执行 StoogeSort(left+k,right);时,使序列的后 2/3 的子序列有序,经过这两次递归排序,使原序列的后 1/3 的位置上是整个序列中较大的数,即序列后 1/3 的位置上数均大于前 2/3 的数,但此时,前 2/3的序列并不一定是有序的。再次执行 StoogeSort(left,right-k);使序列的前 2/3 有序。经过三次递归,最终使序列有序。所以,这一排序算法是正确的。(2)最坏情况发生在序列按递减次序排列。设322in,则log1log3 1ni。冒泡排序最坏时间复杂度为2n,队排序最坏时间复杂度为lognn,快速排序最坏时间复杂度为lognn
8、。所以,该算法不如冒泡排序,堆排序,快速排序。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+)-第 5
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 算法 设计 分析 C+ 语言 描述 陈慧南版 课后 答案
限制150内