为了账号安全,请及时绑定邮箱和手机立即绑定

简单的百度校招题,看有多种解法?

简单的百度校招题,看有多种解法?

慕哥9229398 2019-03-07 10:11:20
查看完整描述

5 回答

?
哈士奇WWW

TA贡献1799条经验 获得超6个赞

我没有做过这道题目,临时想到的算法:

对目标解二分,假设当前数是num,那么遍历每一行,对于第i行,不大于num的数字个数是min(num / i, m),累加之后得到总的计数cnt

如果cnt小于k那么到右半区间继续找;否则到左半区间继续找。

时间复杂度O(n * log(n * m)),绰绰有余。


查看完整回答
反对 回复 2019-04-18
?
慕标5832272

TA贡献1966条经验 获得超4个赞

直接使用下标查询,每一行都是第一行的倍数


查看完整回答
反对 回复 2019-04-18
?
慕田峪9158850

TA贡献1794条经验 获得超7个赞

可以发现乘法表计算结果的大小是按照对角线排列的,因此按照这个方法找规律即可。


查看完整回答
反对 回复 2019-04-18
?
拉丁的传说

TA贡献1789条经验 获得超8个赞

n*m的矩阵结果你是一定需要的。
我给你个方法,造一个0-n*m的数组A,每个元素都为0,
然后你两个for循环计算出矩阵中的每个数t,将A[t]++,
计算完了之后你有一个一维数组可能是这样的【0,1,2,3,1,0,2,5,。。。】
你从左往右加,直到到结果大于等于K,此时的下标i就是你要的结果

查看完整回答
反对 回复 2019-04-18
?
月关宝盒

TA贡献1772条经验 获得超5个赞

def multiply(n, m, k):

    if k > n * m:

        return None


    l = []

    for i in range(1, n + 1):

        for j in range(1, m + 1):

            l.append(i * j)


    return l[k]


print multiply(2,3, 7)


查看完整回答
反对 回复 2019-04-18
  • 5 回答
  • 0 关注
  • 661 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信