zoukankan      html  css  js  c++  java
  • 随机数生成解析

          我们平时在做一些分析数据的时候经常会用到随机数,我们知道,随机数是一个设备,在利用这个设备生成随机数时,需要提供一个种子,如果我们不提供,那么默认会提供一个为1的种子,这时,随机数生成器生成的并不是真正意义上的随机数,因为每次那些随机数都是相同的,例如下面的这个例子:

    #include<stdio.h>
    #include<stdlib.h>
    #include<time.h>
    
    void print_rand();
    
    int main(void)
    {
    	print_rand();
    	printf("
    ");
    }
    
    void print_rand()
    {
    	int a[10], i;
    	
    	
    	for(i = 0; i < 10; i++)
    	{
    		a[i] = rand()%100;
    	}
    	
    	for(i = 0; i < 10; i++)
    	{
    		printf("%d  ", a[i]);
    	}
    }
     


        我现在连续三次执行这个程序,得到如下所示的输出。




     

        现在,我把程序改动如下:

    #include<stdio.h>
    #include<stdlib.h>
    #include<time.h>
    
    void print_rand();
    
    int main(void)
    {
    	print_rand();
    	printf("
    ");
    }
    
    void print_rand()
    {
    	int a[10], i;
    	
    	srand(time(NULL)); 
    	
    	for(i = 0; i < 10; i++)
    	{
    		a[i] = rand()%100;
    	}
    	
    	for(i = 0; i < 10; i++)
    	{
    		printf("%d  ", a[i]);
    	}
    }
     


        同样执行三次,得到的输出如下:




     

        从两次执行的程序可以看出,第一个程序得到的输出都是一样的,因为种子没有变,始终是1,第二个程序输出的每一次都不一样,因为,我用到了这个函数:

    srand(time(NULL)); 

    这个函数是为 rand()提供种子的,为了使每次提供的种子都不一样,我把时间作为参数提供给函数,由于时间肯定是每次都不同的,所以,这样得到的才是真正意义上的随机数。

  • 相关阅读:
    20201016---不做清单
    20201014--增删改查
    20201013--什么是真实的自己?
    多态
    继承
    关键字
    分类思想
    常用的linux命令
    九九乘法表
    稀疏数组
  • 原文地址:https://www.cnblogs.com/keanuyaoo/p/3268634.html
Copyright © 2011-2022 走看看