2014-02-05
展开全部
#include <stdlib.h>
#include <stdio.h>
#include <time.h>
srand()((int)time(NULL));设定随机数种子
rand()()%100;产生0-99的随机数。高级点的,假如要产生16-59之间的数,你可以这样写:rand()()%44+16(这里44由59-16+1得到)。其他情况如法炮制!
各种编程语言返回的随机数(确切地说是伪随机数)实际上都是根据递推公式计算的一组数值,当序列足够长,这组数值近似满足均匀分布。如果计算伪随机序列的初始数值(称为种子)相同,则计算出来的伪随机序列就是完全相同的。这个特性被有的软件利用于加密和解密。加密时,可以用某个种子数生成一个伪随机序列并对数据进行处理;解密时,再利用种子数生成一个伪随机序列并对加密数据进行还原。这样,对于不知道种子数的人要想解密就需要多费些事了。当然,这种完全相同的序列对于你来说是非常糟糕的。要解决这个问题,需要在每次产生随机序列前,先指定不同的种子,这样计算出来的随机序列就不会完全相同了。你可以在调用rand()函数之前调用srand( (unsigned)time( NULL ) ),这样以time函数值(即当前时间)作为种子数,因为两次调用rand函数的时间通常是不同的,这样就可以保证随机性了。你也可以使用srand函数来人为指定种子数。
参考资料:http://zhidao.baidu.com/question/132839023.html
#include <stdio.h>
#include <time.h>
srand()((int)time(NULL));设定随机数种子
rand()()%100;产生0-99的随机数。高级点的,假如要产生16-59之间的数,你可以这样写:rand()()%44+16(这里44由59-16+1得到)。其他情况如法炮制!
各种编程语言返回的随机数(确切地说是伪随机数)实际上都是根据递推公式计算的一组数值,当序列足够长,这组数值近似满足均匀分布。如果计算伪随机序列的初始数值(称为种子)相同,则计算出来的伪随机序列就是完全相同的。这个特性被有的软件利用于加密和解密。加密时,可以用某个种子数生成一个伪随机序列并对数据进行处理;解密时,再利用种子数生成一个伪随机序列并对加密数据进行还原。这样,对于不知道种子数的人要想解密就需要多费些事了。当然,这种完全相同的序列对于你来说是非常糟糕的。要解决这个问题,需要在每次产生随机序列前,先指定不同的种子,这样计算出来的随机序列就不会完全相同了。你可以在调用rand()函数之前调用srand( (unsigned)time( NULL ) ),这样以time函数值(即当前时间)作为种子数,因为两次调用rand函数的时间通常是不同的,这样就可以保证随机性了。你也可以使用srand函数来人为指定种子数。
参考资料:http://zhidao.baidu.com/question/132839023.html
展开全部
用rand函数吧,好久不用C语言,不太记得,貌似是int a=rand()% X(X即范围)这是伪随机数
#include<time.h>
srand(time(NULL));使用前用这条语句初始化
使用int a=rand() / RAND_MAX * n;
就得到真正的随机数
#include<time.h>
srand(time(NULL));使用前用这条语句初始化
使用int a=rand() / RAND_MAX * n;
就得到真正的随机数
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
int a;
随机的。范围是数据类型的任意值
随机的。范围是数据类型的任意值
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询