楼主: WayneBit
跳转到指定楼层
上一主题 下一主题
收起左侧

3/26/2016 vmware oa @ hackerrank 60min

全局:
WayneBit 发表于 2016-4-15 06:17
https://www.hackerrank.com/challenges/detect-the-domain-name

非常感谢,就是原题
但是最后只做了四道题,其中一题还有一个test case没过。。。不知道有没有面试
回复

使用道具 举报

🔗
LumiG 2016-9-3 09:36:44 | 只看该作者
全局:
mrhohn 发表于 2016-4-3 22:04
好吧,查了下,的确是有O(N + K)解法的…

http://stackoverflow.com/questions/24518682/count-subseq ...

第二题自己写了一个,确实O(N+K)就行,觉得比这个的稍简洁好理解一点…就是一个dp吧…

def kSeq(a,k):
    ret = 0
    mods = [0] * k
    for i in a:
        m = i%k
        mods = mods[-m:] + mods[:-m]
        mods[m] += 1
        ret += mods[0]
    return ret


哎这两天要做VM的OA了,现在改成60min5个题了……不知道题目是不是一样。。
回复

使用道具 举报

🔗
LumiG 2016-9-3 09:44:29 | 只看该作者
全局:
哦不对。。我这不是O(N+K), 是O(NK)的。。改一下不要每次更新mods。。只要找个变量记一下当前的值应该加在哪一位上就行了…
回复

使用道具 举报

全局:
其实第二题 o(n) 就可以搞了  比如说 1 2 3 4 1  那么先求出累计和的数组 就是 1 2 6 10 11.
然后再遍历一遍,每个数都除以3,把余数寸成一个数组 1 2 0  1 2.。。找出余数相同的即可
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册账号
隐私提醒:
  • ☑ 禁止发布广告,拉群,贴个人联系方式:找人请去🔗同学同事飞友,拉群请去🔗拉群结伴,广告请去🔗跳蚤市场,和 🔗租房广告|找室友
  • ☑ 论坛内容在发帖 30 分钟内可以编辑,过后则不能删帖。为防止被骚扰甚至人肉,不要公开留微信等联系方式,如有需求请以论坛私信方式发送。
  • ☑ 干货版块可免费使用 🔗超级匿名:面经(美国面经、中国面经、数科面经、PM面经),抖包袱(美国、中国)和录取汇报、定位选校版
  • ☑ 查阅全站 🔗各种匿名方法

本版积分规则

>
快速回复 返回顶部 返回列表