return0;
}
8.有4个人打算过桥,这个桥每次最多只能有两个人同时通过。
他们都在桥的某一端,并且是在晚上,过桥需要一只手电筒,而他们只有一只手电筒。
这就意味着两个人过桥后必须有一个人将手电筒带回来。
每个人走路的速度是不同的:
甲过桥要用1分钟,乙过桥要用2分钟,丙过桥要用5分钟,丁过桥要用10分钟,显然,两个人走路的速度等于其中较慢那个人的速度,问题是他们全部过桥最少要用多长时间?
由于甲过桥时间最短,那么每次传递手电的工作应有甲完成
甲每次分别带着乙丙丁过桥
例如:
第一趟:
甲,乙过桥且甲回来
第二趟:
甲,丙过桥且甲回来
第一趟:
甲,丁过桥
一共用时19小时
9.欧几里德游戏:
开始的时候,白板上有两个不相等的正整数,两个玩家交替行动,每次行动时,当前玩家都必须在白板上写出任意两个已经出现在板上的数字的差,而且这个数字必须是新的,也就是说,和白板上的任何一个已有的数字都不相同,当一方再也写不出新数字时,他就输了。
请问,你是选择先行动还是后行动?
为什么?
设最初两个数较大的为a,较小的为b,两个数的最大公约数为factor。
则最终能出现的数包括:
factor,factor*2,factor*3,...,factor*(a/factor)=a.一共a/factor个。
如果a/factor是奇数,就选择先行动;否则就后行动。
习题2
1.如果T1(n)=O(f(n)),T2(n)=O(g(n)),解答下列问题:
(1)证明加法定理:
T1(n)+T2(n)=max{O(f(n)),O(g(n))};
(2)证明乘法定理:
T1(n)×T2(n)=O(f(n))×O(g(n));
(3)举例说明在什么情况下应用加法定理和乘法定理。
(1)
(2)
(3)比如在
for(f(n))
{
for(g(n))
}
中应该用乘法定理
如果在“讲两个数组合并成一个数组时”,应当用加法定理
(1)intStery(intn)
{
intS=0;
for(inti=1;i<=n;i++)
S=S+i*i;
returnS;
}
(2)intQ(intn)
{
if(n==1)
return1;
else
returnQ(n-1)+2*n-1;
}
2.考虑下面的算法,回答下列问题:
算法完成什么功能?
算法的基本语句是什么?
基本语句执行了多少次?
算法的时间复杂性是多少?
(1)完成的是1-n的平方和
基本语句:
s+=i*i,执行了n次
时间复杂度O(n)
(2)
(2)完成的是n的平方
基本语句:
returnQ(n-1)+2*n–1,执行了n次
时间复杂度O(n)
3.分析以下程序段中基本语句的执行次数是多少,要求列出计算公式。
(1)for(i=1;i<=n;i++)
if(2*i<=n)
for(j=2*i;j<=n;j++)
y=y+i*j;
(2)m=0;
for(i=1;i<=n;i++)
for(j=1;j<=2*i;j++)
m=m+1;
(1)基本语句2*i基本语句y=y+i*j执行了2/n次
一共执行次数=n/2+n/2=O(n)
(2)基本语句m+=1执行了(n/2)*n=O(n*n)
4.使用扩展递归技术求解下列递推关系式:
(1)
(2)
(1)intT(intn)
{
if(n==1)
return4;
elseif(n>1)
return3*T(n-1);
}
(2)
intT(intn)
{
if(n==1)
return1;
elseif(n>1)
return2*T(n/3)+n;
}
5.求下列问题的平凡下界,并指出其下界是否紧密。
(1)求数组中的最大元素;
(2)判断邻接矩阵表示的无向图是不是完全图;
(3)确定数组中的元素是否都是惟一的;
(4)生成一个具有