这是我第一次编程题全部ac的笔试。我个人觉得编程难度不算大。
第一道固数和与三数和的题差不多。
第三道最大公倍数,排序取最大值,然后遍历最大值的倍数就可以。
主要说说第二题的概率题吧。我还是很喜欢编程题的数学题的。
题(记忆):k个小鸟飞n个树,问k至少多少可以是至少有两只鸟在同一棵树的概率大于p?
梦回高中哈哈哈哈哈。
首先,我们需要解决的是问题是:至少有两只鸟在同一棵树的概率。
所以至少有两只鸟在同一棵树的概率是:
因此,该问题可以转化成:求k最小值,满足
两边取log
因此反映到编程里就是:
n,p = map(int,input().split())
if p = 0:
print(0)
if p = 1:
print(n+1)
else:
temp = 0
target = math.log(1-p,2)
for k in range(1,n):
temp += log(n-k+1,2)
temp_past = k*math.log(n,2)
if temp-temp_past >= target:
print(k)
break
#oppo秋招#