12
返回列表 发新帖
楼主: raychainmah
跳转到指定楼层
上一主题 下一主题
收起左侧

A intern 面经

🔗
transcendence 2013-1-31 13:36:07 | 只看该作者
全局:
本帖最后由 transcendence 于 2013-1-31 13:37 编辑
raychainmah 发表于 2013-1-31 11:53
一直再想这个问题,想要证明概率想等,最后看时间不多就整了个用rand取index然后用个flag数组纪录index是 ...

想了想,大概可以这么做:
for i from 0 to input.length
    j = random number between i and n
    swap input input[j]

这样每个数都有相等的机会换到这个数组的任意位置。
时间复杂度如果生成随机数是O(1) , 那么总共应该就是O(n)了
这种题还真没见过啊。。。看来我见的题还只是冰山一角。。。
回复

使用道具 举报

🔗
搬砖工 2013-1-31 23:16:49 | 只看该作者
全局:
transcendence 发表于 2013-1-31 13:36
想了想,大概可以这么做:
for i from 0 to input.length
    j = random number between i and n

思路大概是这样的了。不过从N到1这个逆序比较好写。能保证每个数的概率都是1/n
回复

使用道具 举报

🔗
jwzxgo 2013-2-3 07:05:47 | 只看该作者
全局:
第三题我考虑也可以这样写:
for i in range(0, n):
    swap(a[i], a[rand(i+1, n)])

证明:
第 k 个元素 a[k-1] 被放到位置 i (0 indexed) 的概率 = (n-1)/n * (n-2)/(n-1) * ... * (n-i)/(n-i+1) * 1/(n-i) = 1/n
回复

使用道具 举报

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

本版积分规则

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