如何实现C语言中生成唯一不重复的随机整数?
- 内容介绍
- 文章标签
- 相关推荐
本文共计462个文字,预计阅读时间需要2分钟。
cpp#include #include #include
std::vector generateUniqueRandomNumbers(int n, int m, int k) { std::vector numbers; std::srand(std::time(nullptr)); // Use current time as seed for random generator
// Generate k unique random numbers while (numbers.size() return numbers;} int main() { int n, m, k; std::cout <> n >> m >> k; std::vector uniqueNumbers=generateUniqueRandomNumbers(n, m, k); std::cout << Generated unique random numbers: ; for (int num : uniqueNumbers) { std::cout < return 0;} 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;
}
运行结果: 这个程序可以用于班级内部按照学号进行随机抽签。 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持自由互联。
本文共计462个文字,预计阅读时间需要2分钟。
cpp#include #include #include
std::vector generateUniqueRandomNumbers(int n, int m, int k) { std::vector numbers; std::srand(std::time(nullptr)); // Use current time as seed for random generator
// Generate k unique random numbers while (numbers.size() return numbers;} int main() { int n, m, k; std::cout <> n >> m >> k; std::vector uniqueNumbers=generateUniqueRandomNumbers(n, m, k); std::cout << Generated unique random numbers: ; for (int num : uniqueNumbers) { std::cout < return 0;} 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;
}
运行结果: 这个程序可以用于班级内部按照学号进行随机抽签。 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持自由互联。

