c语言中怎样使产生的随机数是二位整数
本文由青松原创并依GPL-V2及其后续版本发放,转载请注明出处且应包含本行声明。\x0d\x0a\x0d\x0aC++中常用rand()函数生成随机数,但严格意义上来讲生成的只是伪随机数(pseudo-random integral number)。生成随机数时需要我们指定一个种子,如果在程序内循环,那么下一次生成随机数时调用上一次的结果作为种子。但如果分两次执行程序,那么由于种子相同,生成的“随机数”也是相同的。\x0d\x0a\x0d\x0a在工程应用时,我们一般将系统当前时间(Unix时间)作为种子,这样生成的随机数更接近于实际意义上的随机数。给一下例程如下:\x0d\x0a\x0d\x0a#include \x0d\x0a#include \x0d\x0a#include \x0d\x0ausing namespace std;\x0d\x0a\x0d\x0aint main()\x0d\x0a{\x0d\x0a double random(double,double);\x0d\x0a srand(unsigned(time(0)));\x0d\x0a for(int icnt = 0; icnt != 10; ++icnt)\x0d\x0a cout << "No." << icnt+1 << ": " << int(random(0,10))<< endl;\x0d\x0a return 0;\x0d\x0a}\x0d\x0a\x0d\x0adouble random(double start, double end)\x0d\x0a{\x0d\x0a return start+(end-start)*rand()/(RAND_MAX + 1.0);\x0d\x0a}\x0d\x0a/* 运行结果\x0d\x0a* No.1: 3\x0d\x0a* No.2: 9\x0d\x0a* No.3: 0\x0d\x0a* No.4: 9\x0d\x0a* No.5: 5\x0d\x0a* No.6: 6\x0d\x0a* No.7: 9\x0d\x0a* No.8: 2\x0d\x0a* No.9: 9\x0d\x0a* No.10: 6\x0d\x0a*/\x0d\x0a利用这种方法能不能得到完全意义上的随机数呢?似乎9有点多哦?却没有1,4,7?!我们来做一个概率实验,生成1000万个随机数,看0-9这10个数出现的频率是不是大致相同的。程序如下:\x0d\x0a#include \x0d\x0a#include \x0d\x0a#include \x0d\x0a#include \x0d\x0ausing namespace std;\x0d\x0a\x0d\x0aint main()\x0d\x0a{\x0d\x0a double random(double,double);\x0d\x0a int a[10] = ;\x0d\x0a const int Gen_max = 10000000;\x0d\x0a srand(unsigned(time(0)));\x0d\x0a \x0d\x0a for(int icnt = 0; icnt != Gen_max; ++icnt)\x0d\x0a switch(int(random(0,10)))\x0d\x0a {\x0d\x0a case 0: a[0]++; break;\x0d\x0a case 1: a[1]++; break;\x0d\x0a case 2: a[2]++; break;\x0d\x0a case 3: a[3]++; break;\x0d\x0a case 4: a[4]++; break;\x0d\x0a case 5: a[5]++; break;\x0d\x0a case 6: a[6]++; break;\x0d\x0a case 7: a[7]++; break;\x0d\x0a case 8: a[8]++; break;\x0d\x0a case 9: a[9]++; break;\x0d\x0a default: cerr << "Error!" << endl; exit(-1);\x0d\x0a }\x0d\x0a \x0d\x0a for(int icnt = 0; icnt != 10; ++icnt)\x0d\x0a cout << icnt << ": " << setw(6) << setiosflags(ios::fixed) << setprecision(2) << double(a[icnt])/Gen_max*100 << "%" << endl;\x0d\x0a \x0d\x0a return 0;\x0d\x0a}\x0d\x0a\x0d\x0adouble random(double start, double end)\x0d\x0a{\x0d\x0a return start+(end-start)*rand()/(RAND_MAX + 1.0);\x0d\x0a}\x0d\x0a/* 运行结果\x0d\x0a* 0: 10.01%\x0d\x0a* 1: 9.99%\x0d\x0a* 2: 9.99%\x0d\x0a* 3: 9.99%\x0d\x0a* 4: 9.98%\x0d\x0a* 5: 10.01%\x0d\x0a* 6: 10.02%\x0d\x0a* 7: 10.01%\x0d\x0a* 8: 10.01%\x0d\x0a* 9: 9.99%\x0d\x0a*/\x0d\x0a可知用这种方法得到的随机数是满足统计规律的。\x0d\x0a\x0d\x0a另:在Linux下利用GCC编译程序,即使我执行了1000000次运算,是否将random函数定义了inline函数似乎对程序没有任何影响,有理由相信,GCC已经为我们做了优化。但是冥冥之中我又记得要做inline优化得加O3才行...\x0d\x0a\x0d\x0a不行,于是我们把循环次数改为10亿次,用time命令查看执行时间:\x0d\x0achinsung@gentoo ~/workspace/test/Debug $ time ./test \x0d\x0a0: 10.00%\x0d\x0a1: 10.00%\x0d\x0a2: 10.00%\x0d\x0a3: 10.00%\x0d\x0a4: 10.00%\x0d\x0a5: 10.00%\x0d\x0a6: 10.00%\x0d\x0a7: 10.00%\x0d\x0a8: 10.00%\x0d\x0a9: 10.00%\x0d\x0a\x0d\x0areal 2m7.768s\x0d\x0auser 2m4.405s\x0d\x0asys 0m0.038s\x0d\x0achinsung@gentoo ~/workspace/test/Debug $ time ./test \x0d\x0a0: 10.00%\x0d\x0a1: 10.00%\x0d\x0a2: 10.00%\x0d\x0a3: 10.00%\x0d\x0a4: 10.00%\x0d\x0a5: 10.00%\x0d\x0a6: 10.00%\x0d\x0a7: 10.00%\x0d\x0a8: 10.00%\x0d\x0a9: 10.00%\x0d\x0a\x0d\x0areal 2m7.269s\x0d\x0auser 2m4.077s\x0d\x0asys 0m0.025s\x0d\x0a\x0d\x0a前一次为进行inline优化的情形,后一次为没有作inline优化的情形,两次结果相差不大,甚至各项指标后者还要好一些,不知是何缘由...
float b=rand()/(RAND_MAX+1.0);
printf("%f
",b);
注释:
stdlib.h头文件中有宏#define RAND_MAX 0x7fff
rand()产生一个0到0x7ffff即0到32767之间的随机数
rand()/(RAND_MAX+1.0)就等于一个0到1之间的小数了,因为rand()最大是32767最小是0,再除以32768就是一个0到1之间的小数(不能等于1),再乘以10就是一个0到10之间的数了(不等于10).最后再加1,就成了一个求1到10之间随机数的式子了.
#include "stdlib.h"
#include "time.h"
/* main:some simple output */
void main()
{
int num1,num2;
srand((unsigned)time(NULL));
//产生两位数随机数
do
{
num1 = rand()%90+10;
num2 = rand()%90+10;
}while (num1<num2); //如果num2大于num1就重新生成 直到num1大于num2
if (num1>num2)
{
printf("大于");
}
else{
printf("小于");
}
}
10 + rand() % 90
产生后,比较大小,大的作被减数
参考如下:
#include <stdio.h>
#include <stdlib.h>
#include<time.h>
void swap(int* pNum1, int * pNum2)
{
int temp;
temp = *pNum2;
*pNum2 = *pNum1;
*pNum1 = temp;
}
void main()
{
srand(time(0));
for(int i = 0; i < 100 ;++i)
{
char op[2] = {'*','-'};
int num1 = 10 + rand() % 90;
int num2 = 10 + rand() % 90;
int opIndex = rand() % 2;
if(opIndex == 1)
{
if(num1 < num2)
swap(&num1,&num2);
}
printf("%d %c %d \n",num1,op[opIndex],num2);
}
}
%100 即 mod 100
C语言中怎样在随机到一个两位数当它个位和十位的数字相同时后结束产生随...
include <stdio.h> include <stdlib.h> include int main(){ int a;srand(time(NULL));do { a=rand()%90+10;printf("%d\\n",a);}while(a\/10!=a%10);return 0;}
c语言中取随机数的函数
includestdio.h#includestdlib.h#includetime.hvoidmain(){inti;srand((unsigned)time(NULL));i=rand()%100;}这样产生的随机数就是0-99之间的,这二个函数的工作过程如下:1)首先给srand()提供一个种子,它是一个unsignedint类型,其取值范围从0~65535;2)然后调用rand(),它会根据提供给srand()...
C语言编程如何产生一个0-20的随机偶整数
C语言编程产生一个0-20的随机偶整数示例:include<stdio.h> include include<stdlib.h> define NUM 20 \/*生成多少个这样的数*\/ int main(void){ int i;srand(time(NULL)); \/*time(NULL)是得到当前时间,srand()是取一个种子好生成随机数*\/ for(i=0;i<NUM;i++)printf("\\n%d",rand()...
在java中产生随机数
一、利用random方法来生成随机数。在Java语言中生成随机数相对来说比较简单,因为有一个现成的方法可以使用。在Math类中,Java语言提供了一个叫做random的方法。通过这个方法可以让系统产生随机数。不过默认情况下,其产生的随机数范围比较小,为大于等于0到小于1的double型随机数。虽然其随机数产生的范围...
假设产生了13个随机数,在C语言中,如何让他们按照大小排列呢?
\/\/假设产生了13个随机数,在C语言中,如何让他们按照大小排列呢?include<iostream> using namespace std;int const M=13;int main(){ int a[M];int temp;cout<<"请输入13个任意整数:";for(int k=1;k<14;k++){cout<<"NO "<<k<<" ";cin>>a[M];} for(int j=0;j<12;j++)...
c语言中怎样生成随机数?
一、rand函数的基本用法 C语言中的rand函数可以生成一个伪随机数。这个函数返回一个在0到RAND_MAX之间的整数,其中RAND_MAX是一个在stdlib库中定义的常数,通常是一个相当大的数。使用rand函数的基本语法是:`rand`,调用这个函数会返回一个随机数。二、设置随机种子 为了生成不同的随机数序列,需要在...
c语言 产生一个随机数,如何让它每一次运行出现不同的随机数结果?
include "stdio.h"#include "stdlib.h"#include "time.h"int main(void){srand((unsigned)time(NULL)); int a;a=rand()%10;printf("%d\\n",a);}加一句srand((unsigned)time(NULL)); 打开随机触发器 与时钟频率同步 这样每次随机的数就不同 不过需要包含头文件 #include "time.h"...
在C语言编程中,如何实现让电脑随机输出一1~9的整数?
这时候要使用srand()函数来设定产生随机数的种子,一般采用当前时间作为种子,这样可以得到分布比较均匀的伪随机数。rand(),srand()函数位于stdlib.h文件中,取得时间的time()函数位于time.h文件中。rand()%9+1;rand()%9 产生0~8的随机数;rand()%9+1长生1~9的随机数;...
C语言中取随机数的函数
C语言中的随机数生成主要依靠srand()和rand()这两个函数。为了生成随机数,首先需要使用srand()函数来设置随机数种子。种子的值是一个无符号整数,范围从0到65535。设置种子后,通过调用rand()函数,可以生成一个0到32767之间的随机数。如果我们需要生成0到99之间的随机数,可以使用如下代码:int i;sr...
C语言中如何用rand()函数产生20-90的随机整数
9 4 8 8 10 2 4 8 3 6 9 4 8 8 10 2 4 8 3 6 \/\/再次执行仍然产生相同的随机数 srand(设置随机数种子)表头文件:#include<stdlib.h> 定义函数:void srand (unsigned int seed);函数说明:srand()用来设置rand()产生随机数时的随机数种子。参数seed必须是个整数,通常可以利用geypid(...