一亩三分地论坛

 找回密码
 Sign Up 注册获取更多干货
码农求职神器Triplebyte:
不用海投,内推多家公司面试
游戏初创公司
招聘工程师、Designer和游戏策划
游戏初创公司DreamCraft招聘工程师、UIUX Designer和游戏策划
把贵司招聘信息放这里
查看: 952|回复: 8
收起左侧

狗家跪经

[复制链接] |试试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的最优解法吗?
roosterxie 发表于 2017-12-5 13:19:40 | 显示全部楼层
https://stackoverflow.com/questions/23971365/weighted-randomized-ordering. 鍥磋鎴戜滑@1point 3 acres
  1. 鏉ユ簮涓浜.涓夊垎鍦拌鍧.
  2. You have items with weights:. more info on 1point3acres.com

  3. Item A, weight 42
  4. Item B, weight 5.鐣欏璁哄潧-涓浜-涓夊垎鍦
  5. Item C, weight 96. more info on 1point3acres.com
  6. Item D, weight 33. more info on 1point3acres.com
  7. First add up all the weights: 42 + 5 + 96 + 33 = 176

  8. 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.

  9. Compare r with the ranges defined by the weights:

  10. 0 <= r < 42: select item A.
  11. 42 <= r < 47 (= 42 + 5): select item B.
  12. 47 <= r < 143 (= 47 + 96): select item C.
  13. 143 <= r < 176 (= 143 + 33): select item D.
  14. 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.
复制代码

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

使用道具 举报

hychin 发表于 2017-12-5 08:10:44 | 显示全部楼层
啥叫shuff array with weight? 解释下?
回复 支持 反对

使用道具 举报

hychin 发表于 2017-12-14 10:24:58 | 显示全部楼层
roosterxie 发表于 2017-12-5 13:19
https://stackoverflow.com/questions/23971365/weighted-randomized-ordering
.鐣欏璁哄潧-涓浜-涓夊垎鍦
这个应该是最简单的方法 ...

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

使用道具 举报

littlegrass 发表于 2017-12-30 05:16:40 | 显示全部楼层
hychin 发表于 2017-12-14 10:24. 鍥磋鎴戜滑@1point 3 acres
你这个办法是O(n^2),我研究了下,这个题用二叉树可以做到nlogn

请问下 如何用二叉树可以做到nlogn
回复 支持 反对

使用道具 举报

kaixinNI 发表于 2017-12-31 13:36:21 | 显示全部楼层
littlegrass 发表于 2017-12-30 05:16
请问下 如何用二叉树可以做到nlogn
. Waral 鍗氬鏈夋洿澶氭枃绔,
你好,想请问怎么用二叉树做到nlogn呢? 谢谢!
回复 支持 反对

使用道具 举报

kaixinNI 发表于 2017-12-31 13:37:29 | 显示全部楼层
hychin 发表于 2017-12-14 10:24
你这个办法是O(n^2),我研究了下,这个题用二叉树可以做到nlogn

你好,想请问怎么用二叉树做到nlogn呢? 谢谢! 刚才不小心回复错了
回复 支持 反对

使用道具 举报

IsingModel 发表于 2017-12-31 16:20:09 | 显示全部楼层
https://www.quora.com/Is-there-a-simple-O-nlogn-algorithm-for-Weighted-Shuffling-of-cards
可以nlogn 但是得自己建树  写起来应该比较麻烦吧
回复 支持 反对

使用道具 举报

本版积分规则

关闭

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

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

custom counter

GMT+8, 2018-2-26 03:25

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

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