一、已知下列递推式:
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=cx bcx
f(n)= d a cx logca bcx
n a cx x n
若 a≠cx
解:令F(n) = C(n) – 1
则 F(n) = 0 n=1
F(n) = 2C(n/2) + n – 2 n>=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 + 1
C(n)的渐进复杂性是O(nlog2n)
二、由于Prim算法和Kruskal 算法设计思路的不同,导致了其对不同问题实例的效率对比关系的不同。请简要论述:
1、如何将两种算法集成,以适应问题的不同实例输入;
2、你如何评价这一集成的意义?
答:
1、Prim算法基于顶点进行搜索,所以适合顶点少边多的情况。
Kruskal从边集合中进行搜索,所以适合边少的情况。
根据输入的图中的顶点和边的情况,边少的选用kruskal算法,顶点少的选用prim算法
2、没有一个算法是万能的,没有一个算法是对所有情况都适合的。这一集成体现了针对具体问题选用最适合的方法,即具体问题具体分析的哲学思想。
三、分析以下生成排列算法的正确性和时间效率:
HeapPermute(n)
//实现生成排列的Heap算法