c语言,如何产生随机数

c语言,如何产生随机数,第1张

本文由青松原创并依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\x0adouble random(double,double)\x0d\x0asrand(unsigned(time(0)))\x0d\x0afor(int icnt = 0icnt != 10++icnt)\x0d\x0acout <<"No." <<icnt+1 <<"芦伍: " <<int(random(0,10))<<endl\x0d\x0areturn 0\x0d\x0a}\x0d\x0a\x0d\x0adouble random(double start, double end)\x0d\x0a{\x0d\x0areturn 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\x0adouble random(double,double)\x0d\x0aint a[10] = \x0d\x0aconst int Gen_max = 10000000\x0d\x0asrand(unsigned(time(0)))\x0d\x0a\x0d\x0afor(int icnt = 0icnt != Gen_max++icnt)\x0d\x0aswitch(int(random(0,10)))\x0d\x0a{\x0d\x0acase 0: a[0]++break\x0d\x0acase 1: a[1]++break\x0d\x0acase 2: a[2]++break\x0d\x0acase 3: a[3]++break\x0d\x0acase 4: a[4]++break\x0d\x0acase 5: a[5]++break\x0d\x0acase 6: a[6]++break\x0d\x0acase 7: a[7]++break\x0d\x0acase 8: a[8]++break\x0d\x0acase 9: a[9]++break\x0d\x0adefault: cerr <<"Error!" <<endlexit(-1)\x0d\x0a}\x0d\x0a\x0d\x0afor(int icnt = 0icnt != 10++icnt)\x0d\x0acout <<icnt <<": " <<setw(6) <<setiosflags(ios::fixed) <<setprecision(2) <<double(a[icnt])/Gen_max*100 <<"%" <<endl\x0d\x0a\x0d\x0areturn 0\x0d\x0a}\x0d\x0a\x0d\x0adouble random(double start, double end)\x0d\x0a{\x0d\x0areturn 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\x0areal2m7.768s\x0d\x0auser2m4.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\x0areal2m7.269s\x0d\x0auser2m4.077s\x0d\x0asys 0m0.025s\x0d\x0a\x0d\x0a前一次为进行inline优化的情形,后一次为没有作inline优化的情形,两次结果相差不大,甚至各项指标后者还要好一些,不知是何缘由...

在实际编程中,我们经常需要生成随机数。在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语言输出一个1到100的随机数

include <stdio.h>

#include<time.h>

#include<stdlib.h>

main()

{

int i;

srand(time(0));

i=rand()%100+1;/*随机函数*/

printf("%d",i);。

C语言怎样输出一组随机数据

嗯~

代码诠释一下

#include <stdio.h>

#include <time.h>

#include <stdlib.h>

#define N 10

main()

{

int a[N],i,j

srand(time(NULL))

for(i=0i<Ni++)

{

do

{

a[i]=rand()%100+1随机数

for(j=0j<ij++)

if(a[j]==a[i])

break

}while(j<i)

}

for(i=0i<10i++)

printf("%4d",a[i])

}

用c语言出一个随机数,怎么编

你说产生一个随即数,还是产生很数山森多随即数,然后排序?然后还要查找?查找什么数?题目说清楚ok?

产生50个随即数,然后排序可以办到,那么查找显示出什么数?

根据你的要求题意,程序如下,运行正常。

#include<stdio.h>

#include<stdlib.h>

#include<time.h>

main()

{

int a[50]

int i,j,k,temp,n

srand(time(0))/* 设置种子 */

for(i=0i<50i++)

a[i]=rand()/* 随机产生50个数 */

for(i=0i<49i++) /* 排序 */

{

k=i

for(j=i+1j<50j++)

if(a[j]<a[k])k=j

temp=a[k]

a[k]=a[i]

a[i]=temp

}

printf("50个随机数经排序后为:\n")

for(i=0i<50i++)

printf("%d,",a[i])

printf("\n")

printf("请在这50个数中指定一个数:\n")

scanf("%d",&n)

for(i=0i<50i++)

if(a[i]==n)break

printf("这个数是第%d个元素\n",i+1)

getch()

}

另外,站长团上有产品团购,便宜有保证

C语言中如何同时输出100个随机数

#include <stdio.h>

#include <唯睁time.h>

#include <stdlib.h>

int main()

{

srand(time(NULL))

for (int i=0i<=50i++)

{

int a=rand()%1000

int b=rand()%10000

printf("%d,%d\n",a,b) }

return 0

}

怎样薯亩用c语言生成n个随机数

产生一定范围随机数的通用表示公式

要取得[a,b)的随机整数,使用(rand() % (b-a))+ a

要取得[a,b]的随机整数,使用(rand() % (b-a+1))+ a

要取得(a,b]的随机整数,使用(rand() % (b-a))+ a + 1

通用公式:a + rand() % n;其中的a是起始值,n是整数的范围。

要取得a到b之间的随机整数,另一种表示:a + (int)b * rand() / (RAND_MAX + 1)。

要取得0~1之间的浮点数,可以使用rand() / double(RAND_MAX)。

C语言中怎样把随机数表打乱?我输一组随机数(用rand函数),但是每次运行只输出一个值。怎么办?

呵呵,上面两位的回答都很标准,但是,为了不让你在该给谁分上太难取舍,我还是给更标准的回答吧,让你更好理解 首先想要让计算机模拟随机事件是一件很难很难的事情,因为计算机最大的优点就是守规矩,你想让计算机模拟无规律的随机数生成从本质上甚至是不可实现,通常情况下,我们所说的随机数的输出,仅仅是让计算机获取一切信息,然后根据一连串的算法输出看似随机的数。 如果一个算法依赖的信息够大,且够复杂,人力甚至是机器都难以猜出其中的规律,我们就说输出的数是随机的 同理,你在程序里设计里犯的错误就在于没有一个信息获得的渠道,使计算机空有算法却无法根据信息来计算,输出 一般的,我们以计算机运行的时间来作为随机算法的信息来源,因为时间不会倒退,更不会重复,可以比较好的模拟随机 前面两位所说的种子也就是以时间作为基准,用RAND()函数的算法加工之后再输出数字,来模拟随机数的生成 现给出两种可行的写法,均是输出10个100以内的随机数 #include<stdlib.h>{ int i=0randomize()for(i=0i<10i++) printf("%d\t",random(100))} #include<stdlib.h>#include<time.h>main() { int isrand(time(NULL))for(i=0i<10i++) printf("%d\t",rand()%100)} 你可以自己揣摩其中的区别

怎样用C语言生成10个1到100的不重复的随机数?

/*

7 29 89 2 63 35 34 82 96 87 69 6 44 12 5 93 4 67 46 83

Press any key to continue

*/

#include <stdio.h>

#include <stdlib.h>

#include <time.h>

#define N 20

int main() {

int i,j,flag,num,a[N]

srand((unsigned)time(NULL))

for(i = 0i <N++i) {

num = rand()%98 + 1

flag = 1

for(j = 0j <i++j) {

if(num == a[j]) {

flag = 0

break

}

}

if(flag) a[i] = num

else --i

}

for(i = 0i <N++i)

printf("%d ",a[i])

printf("\n")

return 0

}

c语言 产生一个1~50的随机数

#include<stdio.h>

#include<stdlib.h>

#include<time.h>

void main()

{

int i,temp,tag=1

srand((unsigned)time(NULL))/*使随机数不一样*/

while(tag==1)

{

temp=rand()/*产生随机数*/

if(temp>0&&temp<51)

{

i=temp

printf("i为%d。\n是否退出?1.是;2.否。请选择:",i)/*判断是否结束循环*/

scanf("%d",&temp)

if(temp==1)

tag=0

}

}

}

怎样用java语言编程实现输出一个由10个随机数组成的数组

import java.util.Random

public class text

{

public static void main(String[] args)

{

int[] num = new int[10]

int i

for(i=0i<10i++)

{

Random r = new Random()

num[i] = 1 + r.nextInt(100)

System.out.print(" "+num[i])

}

}

}


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/yw/12389254.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-23
下一篇2023-05-23

发表评论

登录后才能评论

评论列表(0条)

    保存