您的位置:

随机c语言,随机数c++语言

本文目录一览:

C语言如何生成随机数

在VC中设计到随机数有两个函数

srand()

and

rand()

srand()

的作用是是一个种子,提供每次获得随机数的基数而已,rand()根据种子而产生随机数

注意

1:srand()

里的值必须是动态变化的,否则得到的随机数就是一个固定数

2:其实可以不用写srand()

,只用rand()就可以了,省事,简单,例子如下

如果我们想得到一个

0-60的随机数那么可以写成

int

i;

i=rand()%60;

就可以了。

当然最好有个统一的标注如下:

int

i;

srand((unsigned)time(

NULL

));

i=rand()%60;

这样就OK了。

c语言随机数怎么生成

在实际编程中,我们经常需要生成随机数。在c语言中我们通常使用rand方法生成随机数,在调用rand前需要调用srand初始化随机数种子。

电脑:华为MateBook14

系统:Windows10

软件:notepad++等编辑器、gcc编译器1.0

1、使用rand函数生成随机数,rand随机生成一个位于0 ~ RAND_MAX之间的整数。如下图中,我们直接使用rand方法生成10个随机数。

2、程序运行后生成了随机数,但直接使用rand的问题在于,在下次程序调用时,生成的随机数与上次一致。所以,rand函数虽然生成随机数,但可以说是一个伪随机。因为每次调用时,生成数字顺序都是固定的。

3、为了在每次调用时生成不同的随机数,使用srand函数初始化随机数种子。只要随机数种子变化了,那么生成的随机数就会改变。通常,srand使用当前时间作为种子。

4、但使用时间作为随机数种子是否安全呢?我们目前程序执行的速度都太快了,一秒钟对于计算机来说太漫长了。我们将生成随机数的操作定义为函数,然后调用函数两次,看生成的随机数仍然时一样。

5、优化函数也比较简单,在使用时间的基础上,我们还加上一个定增序号。这样能保证就算同一秒钟内多次调用,随机数的种子都是不一样的。

6、通常,我们需要获取一定范围内的随机数。所以,在生成随机数之后我们使用模运算获取对应范围内的数据。如生成0到100内的随机数。

c语言如何实现随机生成多个数组至少要100个

需要准备的材料分别有:电脑、C语言编译器。

1、首先,打开C语言编译器,新建一个初始.cpp文件,例如:test.cpp。

2、在test.cpp文件中,输入C语言代码:

srand((unsigned)time(NULL));

for (int i = 0;i 100; i++) {

printf("%d ", rand());

}

3、编译器运行test.cpp文件,此时成功随机生成了100个随机数。

C语言随机

楼上说的是对的,你的printf里面用了取地址符是不正确的下面是改过的程序

#includestdio.h

#includestdlib.h

#includetime.h

void main( )

{

int a,b,c,x,f;

char C;

while(1)

{

printf("请选择\n");

printf("加法请按1\n");

printf("减法请按2\n");

printf("乘法请按3\n");

printf("除法请按4\n");

printf("输入其他退出\n");

scanf("%d",x);

srand( (unsigned)time( NULL ) );

if (x5) switch(x)

{

case 1:a=rand()%100;

b=rand()%100;

printf("%2d+%2d=\n",a,b);

printf("请输入a+b的答案\n") ;

scanf("%d",c);

if (c==(a+b))printf("very good\n\n");

else printf("需要努力\n答案是%d ",a+b);

break;

case 2:a=rand()%100 ;

b=rand()%100;

if (ab){f=a;a=b;b=f;}

printf("%d-%d\n",a,b);

printf("请输入a-b的答案\n") ;

scanf("%d",c);

if (c==(a-b)) printf("very good\n\n");

else printf("需要努力\n答案是%d ",a-b);

break;

case 3: a=rand()%100 ;

b=rand()%100 ;

printf("%d*%d\n",a,b);

printf("请输入a*b的答案") ;

scanf("%d",c);

if (c==(a*b)) printf("very good\n\n");

else printf("需要努力\n答案是%d ",a*b);

break;

case 4: a=rand()%100 ;

b=rand()%100 ;

if (ab)

{f=a;

a=b;

b=f;

}

printf("%d/%d\n",a,b);

printf("请输入a除b的答案") ;

scanf("%d",c);

if (c==(a/b)) printf("very good\n\n");

else printf("需要努力\n答案是%d ",a/b);

break;

}

else printf("确定要退出吗?y/n\n");

scanf("%c",C);

if(C=='y')break;

}

}

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优化的情形,两次结果相差不大,甚至各项指标后者还要好一些,不知是何缘由...

c语言怎么生成随机数?

你好!

完整的代码,红圈处就是从上面100个数字中抽取到的数字:

#include stdio.h

#includestdlib.h                  //生成随机数用 

#includetime.h                    //利用时间生成种子 

#includemath.h                    

int main()

{

      int i;

  int a[100];

      srand( time(NULL) );         //生成种子 

      for(i=0;i100;i++)

      {

       a[i]=rand()%1000+1000;      //生成一个小于1000的随机数

                               //然后加1000,变成 1000 - 2000之间的数 

       printf("%d  ",a[i]);       //打印 

      }

       i=rand()%100;              //随机抽取其中的一个数 

       printf("\n抽取到的是:%d\n",a[i]);//打印 

      

      return 0; 

}