当前位置: 首页 > 面试经验 >

笔试:(编程题)oppo算法工程师(测试方向)-【算法类】

优质
小牛编辑
137浏览
2023-03-28

笔试:(编程题)oppo算法工程师(测试方向)-【算法类】

这是我第一次编程题全部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秋招#
 类似资料: