近期论坛无法登录的解决方案


一亩三分地论坛

 找回密码
 获取更多干活,快来注册

一亩三分地官方iOS手机应用下载
查看: 1559|回复: 5
收起左侧

Twitter Intern OA 2題

[复制链接] |试试Instant~ |关注本帖
rasca0027 发表于 2016-11-2 15:03:02 | 显示全部楼层 |阅读模式

2017(4-6月) 码农类 硕士 实习@Twitter - 网上海投 - 在线笔试 |Other其他

注册一亩三分地论坛,查看更多干货!

您需要 登录 才可以下载或查看,没有帐号?获取更多干活,快来注册

x
今天打開來發現只有兩題
第一題是Genetic Mutation 這題和LC433 Minimum Genetic Mutation 一樣
不過時間要求比較嚴格 我LC上隨便就過的
結果在OA上一直time out @@.鐣欏璁哄潧-涓浜-涓夊垎鍦
第二題是前面很多人討論過的 time series aggregation

鏉ユ簮涓浜.涓夊垎鍦拌鍧.
請原諒我沒有權限po截圖

评分

3

查看全部评分

 楼主| rasca0027 发表于 2016-11-3 14:53:10 | 显示全部楼层
关注一亩三分地公众号:
Warald_一亩三分地
Genetic Mutation Python Code:


  1. def findMutationDistance(start, end, bank):. 鍥磋鎴戜滑@1point 3 acres
  2.     nu_start = toNumber(start)
  3.     nu_end = toNumber(end)
  4.     nu_bank = set(map(toNumber, bank)). 鐣欏鐢宠璁哄潧-涓浜╀笁鍒嗗湴
  5.     explored = set()
  6.     if nu_end not in nu_bank:. 1point 3acres 璁哄潧
  7.         return -1
  8.     if nu_start == nu_end:
  9.         return 0
  10.     fringe = [(nu_start, 0)]
  11.     while fringe != []:.鏈枃鍘熷垱鑷1point3acres璁哄潧
  12.         node = fringe.pop(0)
  13.         now = node[0]. 涓浜-涓夊垎-鍦帮紝鐙鍙戝竷
  14.         depth = node[1]
  15.         
  16.         if now == nu_end:. more info on 1point3acres.com
  17.             return depth
  18.         for x in range(8):
  19.             for y in range(4):
  20.                 successor = now ^ (y << (x * 2)) 鏉ユ簮涓浜.涓夊垎鍦拌鍧.
  21.                 if successor in nu_bank and successor not in explored:
  22.                     explored.add(successor)
  23.                     fringe.append((successor, depth + 1))
  24.     return -1. From 1point 3acres bbs


  25. def toNumber(s):. 鐣欏鐢宠璁哄潧-涓浜╀笁鍒嗗湴
  26.     # s to bi. 鐣欏鐢宠璁哄潧-涓浜╀笁鍒嗗湴
  27.     table = {'A':0, 'C':1, 'G':2, 'T':3}
  28.     val = 0
  29.     for i in s:
  30.         val = table[i] + (val << 2)
  31.     return val
复制代码
回复 支持 反对

使用道具 举报

 楼主| rasca0027 发表于 2016-11-3 14:55:08 | 显示全部楼层
关注一亩三分地微博:
Warald
我過了 已補上代碼在一樓
回复 支持 反对

使用道具 举报

天天甜甜去美国 发表于 2016-11-5 05:02:52 | 显示全部楼层
rasca0027 发表于 2016-11-3 14:55
我過了 已補上代碼在一樓

楼主 求第二题的代码!
回复 支持 反对

使用道具 举报

 楼主| rasca0027 发表于 2016-11-5 05:22:21 | 显示全部楼层
  1. interval = raw_input().鐣欏璁哄潧-涓浜-涓夊垎鍦
  2. start = interval.split(', ')[0]
  3. end = interval.split(', ')[1]

  4. empty = raw_input(). more info on 1point3acres.com
  5. aggregation = {}
    . visit 1point3acres.com for more.

  6. year = start[:4]. 鐗涗汉浜戦泦,涓浜╀笁鍒嗗湴
  7. month = start[5:7]
  8. while True:.1point3acres缃
  9.     s = year + '-' + month
  10.     if s == end:
  11.         break
  12.     aggregation[s] = {}
  13.     month = int(month) + 1
  14.     if month < 10: .鏈枃鍘熷垱鑷1point3acres璁哄潧
  15.         month = '0' + str(month)
  16.     elif month > 12:
  17.         month = '01'
  18.         year = str(int(year) + 1)
  19.     else:
  20.         month = str(month). Waral 鍗氬鏈夋洿澶氭枃绔,
  21. while True:
  22.     data = raw_input()
  23.     if data == '': . from: 1point3acres.com/bbs
  24.         break
  25.     entry = data.split(', '). 鐣欏鐢宠璁哄潧-涓浜╀笁鍒嗗湴
  26.     month = entry[0][:-3]
  27.     action = entry[1]
  28.     count = int(entry[2])
  29.     if month in aggregation:
  30.         if action in aggregation[month]:
  31.             aggregation[month][action] += count
  32.         else:
  33.             aggregation[month][action] = count.鏈枃鍘熷垱鑷1point3acres璁哄潧

  34. for item in sorted(aggregation, reverse=True):. From 1point 3acres bbs
  35.     if aggregation[item] != {}:
  36.         print item + ', ' + ', '.join(k+', '+ str(aggregation[item][k]) for k in sorted(aggregation[item])). 鍥磋鎴戜滑@1point 3 acres
复制代码
回复 支持 反对

使用道具 举报

本版积分规则

关闭

一亩三分地推荐上一条 /5 下一条

手机版|小黑屋|一亩三分地论坛声明

custom counter

GMT+8, 2017-6-29 19:13

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

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