保姆式解析!!!
题目:
有一群海盗(不多于20人),在船上比拼酒量。过程如下:打开一瓶酒,所有在场的人平分喝下,有几个人倒下了。再打开一瓶酒平分,又有倒下的,再次重复...... 直到开了第4瓶酒,坐着的已经所剩无几,海盗船长也在其中。当第4瓶酒平分喝下后,大家都倒下了。等船长醒来,发现海盗船搁浅了。他在航海日志中写到:“......昨天,我正好喝了一瓶.......奉劝大家,开船不喝酒,喝酒别开船......”
请你根据这些信息,推断开始有多少人,每一轮喝下来还剩多少人。
如果有多个可能的答案,请列出所有答案,每个答案占一行。
格式是:人数,人数,...
例如,有一种可能是:20,5,4,2,0。
分析:只需要判断出每次喝酒前有多少人即可,因为船长是最后一个倒下的,而且喝了正好一瓶,所以
1/a+1/b+1/c+1/d=1,变成乘法后为:bcd+acd+abd+abc=abcd
i = 4 #因为喝了四轮,所以最少得有4个人
while i < 20: #喝酒的总人数不能超过20人
i += 1 #遍历所有可能性的喝酒总人数
j = 1
while j < i: #第一轮倒下的人不能大于喝酒的总人数,不然就细思极恐了!
j += 1 #遍历第一轮可能倒下的人数
k = 1
while k < j: #第二轮倒下的人不能大于第一轮剩下的人
k += 1 #和第六行的意思差不多
l = 1
while l < k: #第三轮倒下的人不能大于第二轮剩下的人
l += 1
if (i != j != k != l): #每轮都会有人倒下,所以这各轮剩下的人不可能一样
#if (1/ i + 1/ j + 1 / k + 1 / l == 1):这行和下行代码的效果是一样的
if (j * k * l + i * k * l + i * j * l + i * j * k == i * j * k * l):
print(i, j, k, l, "0") #第四轮已经没人了,所以就直接输出零,终究还是他们酒量不行!!!
觉得俺写得还行的话,就留下你的点赞!!!关注那再好不过啦!!!
蟹蟹啦!!!
还有,记得收藏!!!