C++生成不重复的随机整数
C++生成不重复的随机数,供大家参考,具体内容如下
给定正整数的范围[n,m],生成k个不重复的随机数字。
IDE是vs013。
#include "stdafx.h"
#include <iostream>
#include <vector>
#include <stdlib.h>
#include <time.h>
#include<list>
using namespace std;
int _tmain(int argc, _TCHAR* argv[])
{
srand((unsigned)time(NULL));
list<int>::iterator it;//迭代器
list<int> l;//定义链表,保存生成的随机数
int begin, end;//数字范围
int sum;//随机数个数
cout << "输入数字范围([n,m]):";
cin >>begin>>end;
cout << "输入随机数个数:";
cin >> sum;
if ( (end<0)||(begin<0)||(begin >end)|| (sum>end))//起始范围必须大于0,且随机数个数小于等于最大数字范围
{
cout << "范围错误";
cout << endl;
system("pause");
return 0;
}
else
{
while (l.size() < sum)
{
l.push_back(rand() % (end - begin + 1) + begin);
l.sort();//排序
l.unique();//去除相邻的重复随机数中的第一个
}
cout << "结果:";
}
for (it = l.begin(); it != l.end(); it++)
{
cout << *it << ' ';
}
cout << endl;
system("pause");
return 0;
}
运行结果:
这个程序可以用于班级内部按照学号进行随机抽签。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
以上是 C++生成不重复的随机整数 的全部内容, 来源链接: utcz.com/p/244557.html