不要追求绝对的公平,红尘之中没有公平而言,人活一世,难得糊涂。
it is no use doing what you like, you have got to like what you do.
过桥问题
上一篇 /
下一篇 2006-12-08 16:04:52
/ 精华(3)
/ 置顶(3)
/ 个人分类:软件测试技术
,K&Fj X0R;jj0c0在漆黑的夜里,四位旅行者来到了一座狭窄而且没有护栏的桥边。如果不借助手电筒的话,大家是无论如何也不敢过桥去的。不幸的是,四个人一共只带了一只手电
筒,而桥窄得只够让两个人同时过。如果各自单独过桥的话,四人所需要的时间分别是1、2、5、8分钟;而如果两人同时过桥,所需要的时间就是走得比较慢的
那个人单独行动时所需的时间。问题是,如何设计一个方案,让这四人尽快过桥。
0`@'T(hmQVO051Testing软件测试网i&whr^%x 假设这四人分别为A、B、C、D。很明显,开始两人拿着手电筒过桥后,手电筒就在桥的另一边了,此时需要已经过桥的那两人中的一个再把手电筒送回桥这
边。送手电筒回来过桥也要化时间,所以要选一个跑得比较快的。一个很自然的想法就是,每次让跑得最快的A陪着另一个过桥,然后A快速地跑回来,再陪下一位
过去,最后所有人就都可以过桥了。
51Testing软件测试网M,p0JV1x#m3b |i)OKx\7V+D0 让我们来算一下这要多长时间。为了方便起见,我们把旅行者出发的桥的这一边称为“
此岸”,而把旅行者想要到达的那边叫“
彼岸”。在表达一个过桥方案时,我们用“←”来表示从彼岸到此岸的移动,用“→”表示从此岸到彼岸的移动。前面“A护送大家过河”的方案就可以写成:(右边数字为完成此步骤所需时间)
Wl
O,cQ;Yo,a[6A0+b&CO]r(U3?P? ~0 A B → 2
Z2XpY5oE1b0 A ← 1
~ G2q.C+sc^0 A C → 551Testing软件测试网PK}$W-JA+K2v?0G
A ← 151Testing软件测试网Lxk6ac_y([
qy2{
A D → 851Testing软件测试网;M7vC9b"P^8aH*cW X0X!F@$a@'_uL0一共就是2+1+5+1+8=17分钟。
'Sq#C9R
X`t0yD:r8t&g]0 但其实有更快的办法:
`-kT,EAw051Testing软件测试网V^~J!y A B → 2
(U-g+_LK-lEA_S0 A ← 1
F,zCn"x3@0 C D → 8
'wQJ,a/ygk\\4H0 B ← 251Testing软件测试网b:B%H`j
Yn
A B → 2
G3P#a;K-M.i([;e&} @H0nAri#YTo0q4s D9C"zsj"q8Bt0一共是2+1+8+2+2=15分钟。这个办法的聪明之处在于让两个走得最慢的人同时过桥,这样花去的时间只是走得最慢的那个人花的时间,而走得次慢的那位就不用另花时间过桥了。可以把所有可能的方案都列举一遍,就会发现这是最快的方案了。
51Testing软件测试网eM1@&rk4S'ry#p1K&r%{G)f3hJ0]px
]0 现在我们把这个问题推广到N(N≥4)个人过桥的情况:如果有N个旅行者,假设他们有各自所需的过桥时间(正实数)。在只有一只手电筒的情况下,要过上述的一条桥,怎样才能找到最快的过桥方案?
+^i.v5We_'Dxn051Testing软件测试网({!}I"l[-m
X/B:c 假设最快地把N个旅行者从此岸移动到彼岸需要f分钟时间,那么我们把所有在f分钟时间内把N个旅行者从此岸移动到彼岸的方案称为“
最佳方案”。最佳方案很有可能不止一个,我们的目的是要找到一个最佳方案,但是并不需要把所有的最佳方案全都找出来
51Testing软件测试网m
a?Xw+b
收藏
举报
TAG:
过桥问题
经典智力题
智力搞笑
幽默笑话
顿悟人生
笑话
幽默