C++生成54个不同的随机数

利用C++生成不同的随机数的函数rand()辅以srand()函数生成0~53之间的54个数字(之所以选择54是因为为洗牌而定)

算法一:先定义一个数组(可以全为0或者同一个数,也可以不赋值),首先利用srand()函数生成一个随机种子,利用rand()函数生成随机数,从第一个数开始进入到数组,每一个与之前的i-1个进行比较  若有相同的则可以重新生成在进行判断;实现代码如下:

</pre><pre name="code" class="html"><span style="font-family: Arial, Helvetica, sans-serif;">int main()</span>
{
	int a[54];
	srand((unsigned)time(NULL));
	for (int i = 0; i < 54; i++)
	{
		a[i] = rand() % 54;
		int j = i;
		while (j--){
			if (a[i] == a[j])
			{
				a[i] = rand() % 54;
				j = i;
			}
		}
		cout << a[i] << ' ';
	}
		cout << endl;
		system("pause");
		return 0;
}
算法2:利用C++STL容器与算法实现 首先定义一个容器,容纳0~53的54个数字,存入时按照升序,然后利用random_shuffle()函数进行打乱,再进行输出即可得到54个不同的随机数,其实现代码如下:

int main()
{
	vector<int>vi;
	for (int i = 1; i <= 54; i++){
		vi.push_back(i);
	}
	vector<int>::iterator it1 = vi.begin();
	while (it1!= vi.end()){
		cout << *it1<<' ';
		it1++;
	}
	cout << endl;
	random_shuffle(vi.begin(), vi.end());
	vector<int>::iterator it2 = vi.begin();
	while (it2 != vi.end()){
		cout << *it2 << ' ';
		it2++;
	}
	cout << endl;
	system("pause");
	return 0;
}
以上是两种简单的生成随机数的算法与实现代码


阅读更多 登录后自动展开
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页