欢迎访问 生活随笔!

生活随笔

当前位置: 首页 > 编程资源 > 编程问答 >内容正文

编程问答

[CareerCup] 18.3 Randomly Generate Integers 随机生成数字

发布时间:2023/12/20 编程问答 35 豆豆
生活随笔 收集整理的这篇文章主要介绍了 [CareerCup] 18.3 Randomly Generate Integers 随机生成数字 小编觉得挺不错的,现在分享给大家,帮大家做个参考.

18.3 Write a method to randomly generate a set of m integers from an array of size n. Each element must have equal probability of being chosen.

这道题让我们从一个数组中随机取出m个数字,要求每个数字被取出的概率相同,其实这道题用的是之前那道18.2 Shuffle Cards的方法,同样我们可以用递归和迭代两种方法来做,递归的思路还用的回溯法,回溯到i+1==m的时候,取出数组中前m个数字放到结果res中,然后一层一层的返回,返回的过程中每次在[0, i]之间取出一个随机数,然后如果这个数小于m,那么更新res[k]的值为nums[i],这样相当于一种洗牌,这样保证了每个数被取出的概率都相同,参见代码如下:

解法一:

vector<int> pick(vector<int> &nums, int m, int i) {if (i + 1 < m) return {};else if (i + 1 == m) {vector<int> res(m);for (int k = 0; k < m; ++k) {res[k] = nums[k];}return res;} else {vector<int> res = pick(nums, m, i - 1);int k = rand() % (i + 1);if (k < m) res[k] = nums[i];return res;} }

当然还有对应的迭代的写法,思路都一样:

解法二:

vector<int> pick(vector<int> &nums, int m) {vector<int> res(m);for (int i = 0; i < m; ++i) {res[i] = nums[i];}for (int i = m; i < nums.size(); ++i) {int k = rand() % (i + 1);if (k < m) res[k] = nums[i];}return res; }

本文转自博客园Grandyang的博客,原文链接:随机生成数字[CareerCup] 18.3 Randomly Generate Integers ,如需转载请自行联系原博主。

总结

以上是生活随笔为你收集整理的[CareerCup] 18.3 Randomly Generate Integers 随机生成数字的全部内容,希望文章能够帮你解决所遇到的问题。

如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。