一、已知下列递推式:C(n)=1若n=1=2C(n/2)+n–1若n≥2请由定理1导出C(n)的非递归表达式并指出其渐进复杂性
定理1:设a,c为非负整数,b,d,x为非负常数,并对于某个非负整数k,令n=ck,则以下递推式f(n)=d若n=1=af(n/c)+bnx若n>=2的解是f(n)=bnxlogcn+dnx若a=cxf(n)=若a≠cx解:令F(n)=C(n)–1则F(n)=0n=1F(n)=2C(n/2)+n–2n>=2=2[F(n/2)+1]+n–2=2F(n/2)+n利用定理1,其中:d=0,a=2,c=2,b=1,x=1,并且a=cx所以F(n)=nlog2n所以C(n)=F(n)+1=nlog2n+1C(n)的渐进复杂性是O(nlog2n)二、由于Prim算法和Kruskal算法设计思路的不同,导致了其对不同问题实例的效率对比关系的不同
请简要论述:1、如何将两种算法集成,以适应问题的不同实例输入;2、你如何评价这一集成的意义
答:1、Prim算法基于顶点进行搜索,所以适合顶点少边多的情况
Kruskal从边集合中进行搜索,所以适合边少的情况
根据输入的图中的顶点和边的情况,边少的选用kruskal算法,顶点少的选用prim算法2、没有一个算法是万能的,没有一个算法是对所有情况都适合的
这一集成体现了针对具体问题选用最适合的方法,即具体问题具体分析的哲学思想
三、分析以下生成排列算法的正确性和时间效率:HeapPermute(n)//实现生成排列的Heap算法//输入:一个正正整数n和一个全局数组A[1
n]//输出:A中元素的全排列ifn=1writeAelsefori←1tondoHeapPermute(n-1)ifnisoddswapA[1]andA[n]elseswapA[i]andA[n]解:n=1时,输出a1n=2时,输出a1a2,a2a1