一亩三分地论坛

 找回密码
 Sign Up 注册获取更多干货
码农求职神器Triplebyte:
不用海投,内推你去多家公司面试
Airbnb 数据科学职位
in analytics and inference
天天打游戏、照样领工资,
你要不要来?
把贵司招聘信息放这里
查看: 412|回复: 4
收起左侧

狗家跪经

[复制链接] |试试Instant~ |关注本帖
crackinterview 发表于 2017-12-5 07:59:22 | 显示全部楼层 |阅读模式

2017(10-12月) 码农类 硕士 全职@Google - 内推 - Onsite |Other在职跳槽

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

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

x
问了一个shuffle array with weight,coding了O(n^2),口头说了另外两种O(n)的,说是不是他想要的,最后也没能做出来,应该是跪了。
有人知道shuffle array with weight的最优解法吗?. 鍥磋鎴戜滑@1point 3 acres
hychin 发表于 2017-12-5 08:10:44 | 显示全部楼层
啥叫shuff array with weight? 解释下?
回复 支持 反对

使用道具 举报

roosterxie 发表于 2017-12-5 13:19:40 | 显示全部楼层
https://stackoverflow.com/questions/23971365/weighted-randomized-ordering

  1. You have items with weights:
  2. . 鐣欏鐢宠璁哄潧-涓浜╀笁鍒嗗湴
  3. Item A, weight 42
  4. Item B, weight 5
  5. Item C, weight 96. visit 1point3acres.com for more.
  6. Item D, weight 33
  7. First add up all the weights: 42 + 5 + 96 + 33 = 176
  8. .1point3acres缃
  9. Now pick a random number, r, from 0 up to the sum of the weights: 0 <= r < 176. I have used integers, but you could use reals if required.

  10. Compare r with the ranges defined by the weights:. 鍥磋鎴戜滑@1point 3 acres

  11. 0 <= r < 42: select item A.
  12. 42 <= r < 47 (= 42 + 5): select item B.
  13. 47 <= r < 143 (= 47 + 96): select item C.
  14. 143 <= r < 176 (= 143 + 33): select item D.
  15. When you have picked the first item, then repeat the process with the three remaining items and a reduced sum of all the weights. Keep repeating until there are no more items to pick.
复制代码

这个应该是最简单的方法了
回复 支持 反对

使用道具 举报

hychin 发表于 7 小时前 | 显示全部楼层
roosterxie 发表于 2017-12-5 13:19. visit 1point3acres.com for more.
https://stackoverflow.com/questions/23971365/weighted-randomized-ordering.鏈枃鍘熷垱鑷1point3acres璁哄潧
-google 1point3acres
这个应该是最简单的方法 ...

你这个办法是O(n^2),我研究了下,这个题用二叉树可以做到nlogn
回复 支持 反对

使用道具 举报

本版积分规则

关闭

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

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

custom counter

GMT+8, 2017-12-14 18:23

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

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