null的值就是0,因此srand(time(null)和srand(time(0))
创新互联专注于企业全网营销推广、网站重做改版、铅山网站定制设计、自适应品牌网站建设、H5响应式网站、商城网站建设、集团公司官网建设、成都外贸网站建设、高端网站制作、响应式网页设计等建站业务,价格优惠性价比高,为铅山等各大城市提供网站开发制作服务。
是一样的。都是0
而
time(time_t
*time)里面的time_t
*time,也就是给指针赋值个0,就是:time
=
null,是允许的。
srand(time(t))
这个也是一个随机种子,t
就是
time_t类型的,一样可以设置随机种子
利用srand((unsigned int)(time(NULL))是一种方法,因为每一次运行程序的时间是不同的。
在C语言里所提供的随机数发生器的用法:现在的C编译器都提供了一个基于ANSI标准的伪随机数发生器函数,用来生成随机数。它们就是rand()和srand()函数。这二个函数的工作过程如下:
1) 首先给srand()提供一个种子,它是一个unsigned int类型,其取值范围从0~65535;
2) 然后调用rand(),它会根据提供给srand()的种子值返回一个随机数(在0到32767之间)
3) 根据需要多次调用rand(),从而不间断地得到新的随机数;
4) 无论什么时候,都可以给srand()提供一个新的种子,从而进一步“随机化”rand()的输出结果。
下面是0~32767之间的随机数程序:
#include stdlib.h
#include stdio.h
#include time.h // 使用当前时钟做种子
void main(void)
{int i;
srand((unsigned)time( NULL ) ); // 初始化随机数
for(i = 0; i 10;i++) // 打印出 10 个随机数
printf("%d\n", rand() );
}
根据上面的程序可以很容易得到0~1之间的随机数:
#include stdlib.h
#include stdio.h
#include time.h
int main( )
{int i;
srand((unsigned)time( NULL ) );
for(i = 0; i 10;i++)
printf("%5.2f\n", rand()/32767.0);
}
而产生1~100之间的随机数可以这样写:
#include stdlib.h
#include stdio.h
#include time.h
int main( )
{int i;
srand((unsigned)time( NULL ) );
for(i = 0; i 10;i++)
printf("%d\n", rand()%100+1);
}
扩展资料:
C语言高效编程技巧:
一:以空间换时间
计算机程序中最大的矛盾是空间和时间的矛盾,那么,从这个角度出发逆向思维来考虑程序的效率问题
二:数学方法解决问题
数学是计算机之母,没有数学的依据和基础,就没有计算机发展,所以在编写程序的时候,采用一些数学方法会对程序的执行效率有数量级的提高。
三:使用位操作
实现高效的C语言编写的第三招----使用位操作,减少除法和取模的运算。
在计算机程序中,数据的位是可以操作的最小数据单位,理论上可以用“位运算”来完成所有的运算和操作。一般的位操作是用来控制硬件的,或者做数据变换使用,但是,灵活的位操作可以有效提高程序运行的效率。
参考资料来源:百度百科-C语言
可以使用C语言标准库中的srand()和rand()来生成随机数,同时要生成1~99之间的随机数,只需要将生成的随机数与99整除,取其余数+1即可保证所有产生的随机数在[1,99]的区间之内。示例代码如下:
#includestdio.h
#includestdlib.h
#includetime.h
int main()
{
int a,i;
srand((unsigned)time(NULL));//初始化随机数
for(i=0;i200;i++)
{
a=rand()%99+1;//随机数的产生调用rand()函数
printf("%d\t",a);
}
printf("\n");
return 0;
}
到底要取多少个是很重要的。 如果就取几个, 那碰上相同的冲取就可以了。如果要取很多很多, 那么重取的方案就不划算了。 比如如果要取100次, 也就是做个全排列, 可以做个表, 每次从表中取数,取完了就把它从表里删除。
#include stdio.h
#include time.h
#include stdlib.h
#define N 100
int main()
{
int candi[N];
int results[N] = {0};
int i, n =N, r;
srand((unsigned)time(0));
for(i=0; iN; ++i) candi[i] = i;
for (i=0; iN; ++i)
{
r = rand()%n;
results[i] = candi[r];
candi[r] = candi[--n];
}
for (i=0; iN; ++i)
{
printf("%d ", results[i]);
}
}