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++随机数生成实例讲解
如果让你用C++来生成0--N-1之间的随机数,你会怎么做?你可能会说,很简单,看: srand( (unsigned)time( NULL ) ); rand() % N; 仔细想一下,这个结果是随机的吗(当然,我们不考虑rand()函数的伪随机性)? 不是的,因为rand()的上限是RAND_MAX,而一般情况下,RAND_MAX并不是N的整数倍,那么如果RAND_MAX % = r,则0--r之间的数值的概率就要大一些,而r+1--N-1之间的数值的概率就要小一些.还有,如果N > RAN
-
C++编写生成不重复的随机数代码
C++编写生成不重复的随机数代码 vector<int> getRandom(int total) { srand((int)time(NULL)); std::vector<int> input = *new std::vector<int>(); for (int i = 0; i < total; i++) { input.push_back(i); } vector<int> output = *new vector<int>();
-
C语言/C++如何生成随机数
本文分享了C语言/C++如何生成随机数的具体实现方法,供大家参考,具体内容如下 C语言/C++怎样产生随机数:这里要用到的是rand()函数, srand()函数,C语言/C++里没有自带的random(int number)函数. (1) 如果你只要产生随机数而不需要设定范围的话,你只要用rand()就可以了:rand()会返回一随机数值, 范围在0至RAND_MAX 间.RAND_MAX定义在stdlib.h, 其值为2147483647. 例如: #include<stdio.h> #i
-
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 arg
-
JS生成不重复的随机数组的简单实例
JS生成不重复的随机数组的简单实例 //获取数组中的随机数 //HF.Math.RandomNumbers是前缀,可以自己定义,主要看逻辑代码 HF.Math.RandomNumbers = function (startNum, endNum, count, repeat) { var ret = []; if (repeat) { for (var i = 0; i < count; i++) { ret[i] = HF.Math.Random(startNum, endNum); } re
-
Python生成不重复随机值的方法
本文实例讲述了Python生成不重复随机值的方法.分享给大家供大家参考.具体分析如下: 这里从一列表中,生成不重复的随机值 算法实现如下: import random total = 100 li = [i for i in range(total)] res = [] num = 20 for i in range(num): t = random.randint(i,total-1) res.append(li[t]) li[t], li[i] = li[i], li[t] print re
-
C#随机生成不重复字符串的两个不错方法
今天整理以前一个项目源码,发现两个随机生成不重复字符串的方法,觉得用起来挺方便的,在此贴出来,方便以后查阅. 方法一:随机生成不重复数字字符串 复制代码 代码如下: private int rep=0; /// <summary> /// 生成随机数字字符串 /// </summary> /// <param name="codeCount">待生成的位数</param> /// <returns>生成的数字字符串</r
-
C#生成不重复随机字符串类
本文实例讲述了C#生成不重复随机字符串类.分享给大家供大家参考.具体如下: 这个C#类用于随机产生不重复的字符串,可以指定字符串范围,可以指定要产生字符串的长度 using System; namespace DotNet.Utilities { public class RandomOperate { // 一:随机生成不重复数字字符串 private int rep = 0; public string GenerateCheckCodeNum(int codeCount) { string
-
python 在指定范围内随机生成不重复的n个数实例
利用Python中的randomw.sample()函数实现 resultList=random.sample(range(A,B),N); #表示从[A,B]间随机生成N个数,结果以列表返回 以上这篇python 在指定范围内随机生成不重复的n个数实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我们.
-
Java超详细讲解如何生成随机整数
目录 1. java.util.Random 2. 数学.随机 3. Java 8 Random.ints 1. java.util.Random 这Random().nextInt(int bound)会生成一个从 0(包括)到 bound(不包括)的随机整数. (1)代码片段 对于getRandomNumberInRange(5, 10),这将生成一个介于 5(含)和 10(含)之间的随机整数. private static int getRandomNumberInRange(int mi
-
Java生成范围内随机整数的三种方法
目录 前言 1. java.util.Random 2.数学随机 3. Java 8 Random.ints 参考文献 总结 前言 在本文中,我们将向您展示三种生成范围内随机整数的方法. java.util.Random.nextInt 数学随机 java.util.Random.ints(Java 8) 1. java.util.Random 此Random().nextInt(int bound)生成一个从0(含)到bound( Random().nextInt(int bound)的随机整
-
javascript 如何生成不重复的随机数
alert(new Date().getTime()) [Ctrl+A 全选 注:如需引入外部Js需刷新才能执行] (new Date().getTime()) ^ Math.random(); 随机且基本上很难重复--那不如这样算了..随机生成不重复的数字,并且还从大到小排列.. function create(n) { var temp=Math.floor(Math.random()*10+n*10); while(--n!=0) { return temp+","+create
-
用C#生成不重复的随机数的代码
对于随机数,大家都知道,计算机不 可能产生完全随机的数字,所谓的随机数发生器都是通过一定的算法对事先选定的随机种子做复杂的运算,用产生的结果来近似的模拟完全随机数,这种随机数被称 作伪随机数.伪随机数是以相同的概率从一组有限的数字中选取的.所选数字并不具有完全的随机性,但是从实用的角度而言,其随机程度已足够了.伪随机数的选 择是从随机种子开始的,所以为了保证每次得到的伪随机数都足够地"随机",随机种子的选择就显得非常重要.如果随机种子一样,那么同一个随机数发生器产生 的随机数也会一样.
随机推荐
- javascript中类的定义及其方式(《javascript高级程序设计》学习笔记)
- 详解iOS开发中UItableview控件的数据刷新功能的实现
- Delphi实现窗体感知鼠标滑过并自动隐藏与显示窗口的方法
- java定时任务的实现方法
- java 自己实现DataSource实现实例
- JSP中c:foreach遍历和s:iterator遍历异同实例分析
- Javascript中的方法链(Method Chaining)介绍
- sql 函数大全 比较常用的一些函数整理第1/2页
- 解读JavaScript代码 var ie = !-[1,] 最短的IE判定代码
- 基于JavaScript 下namespace 功能的简单分析
- Egret引擎开发指南之编译项目
- 浅析string 与char* char[]之间的转换
- 抢滩WindowsServer2008 主机商在行动
- python中print()函数的“,”与java中System.out.print()函数中的“+”功能详解
- java中string.trim()函数的作用实例及源码
- Android RecyclerView的焦点记忆封装
- PHPStorm中如何对nodejs项目进行单元测试详解
- 详解linux系统调用原理
- 基于Vue SEO的四种方案(小结)
- 详解如何使用maven生成可以执行的jar