题目描述
X星系的机器人可以自动复制自己。它们用1年的时间可以复制出2个自己,然后就失去复制能力。
每年X星系都会选出1个新出生的机器人发往太空。也就是说,如果X星系原有机器人5个,
1年后总数是:5 + 9 = 14
2年后总数是:5 + 9 + 17 = 31
如果已经探测经过n年后的机器人总数s,你能算出最初有多少机器人吗?
输入
输入存在多组测试数据
对于每组测试数据,输入一行两个数字n和s,用空格分开,含义如上。n不大于100,s位数不超过50位。
输出
对于每组测试数据,要求输出一行,一个整数,表示最初有机器人多少个。
样例输入
2 31
97 2218388550399401452619230609499
样例输出
5
8
数学题,找规律
设初始a人,我们设前n年增加的人数分别为的为2n-1,4n-3,8n-7,.。。。
然后总人数就是n*(2^n-1)-@@@
暴力过一遍就能解方程了
while True:
n,s = map(int,input().split())
sum = 0
w = 1
for i in range(n):
sum+=w
w = w*2+1
#print(sum)
bei = 2**(n+1)-1
s +=sum
print(s//bei)