如何产生n个不重复的随机数

问题:如何得到n个互相不重复的随机数?


用过Matlab的朋友,应该会见到过这样一个函数:randperm(n),用途是产生n个不重复的随机数。C和C++中也有用于产生随机数的rand()函数。那么,如何借助这个函数去实现randperm(n)的效果呢?本文提供三种常见思路,如下:


思路1:

创建一个动态数组,每次产生一个随机数,并判断该动态数组是否含有这一随机数。如果有,则跳过并重新产生下一个随机数;如果没有,则将产生的这一随机数加入动态数组。循环直到动态数组中元素数量达到n。


vector<int> random1(int number)
{
	vector<int> result;
	result.clear();
	result.reserve(number);
	srand((int)time(0));
	while (result.size() < number)
	{
		int value = rand() % number;
		bool flag = true;
		for (size_t i = 0; i < result.size(); i++)
		{
			if (result.at(i) != number) continue;
			else
			{
				flag = false;
				break;
			}
		}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值