转自:http://baike.baidu.com/link?url=bhos65ZKp8lEq_6chSsmQv29jHrqjN_IFGVMNod6BuicQ-3oCP5VsEn3RBjXBPvA7RGgcXq2yKS9wDiNgJXjIa#2

srand函数是随机数发生器的初始化函数。原型:voidsrand(unsigned int seed);

srand和rand()配合使用产生伪随机数序列。rand函数在产生随机数前,需要系统提供的生成伪随机数序列的种子,rand根据这个种子的值产生一系列随机数。如果系统提供的种子没有变化,每次调用rand函数生成的伪随机数序列都是一样的。srand(unsigned seed)通过参数seed改变系统提供的种子值,从而可以使得每次调用rand函数生成的伪随机数序列不同,从而实现真正意义上的“随机”。通常可以利用系统时间来改变系统的种子值,即srand(time(NULL)),可以为rand函数提供不同的种子值,进而产生不同的随机数序列

#include<stdlib.h>/*用到了srand函数,所以要有这个头文件*/
#include<stdio.h>
#define MAX 10
 
int main(void)
{
int number[MAX] = {0};
int i;
unsigned int seed;
scanf("%d",&seed);/*手动输入种子*/
srand(seed);
for(i = 0; i < MAX; i++)
{
number[i] = rand() % 100;/*产生100以内的随机整数*/
printf("%d",number[i]);
}
printf("\n");
return 0;
}
注:seed是一个种子,一般srand()和rand()组合使用,rand每次产生的随机数要根据seed的值来随机,如果数一样那么随机值也一样,其实rand()内部是同余计算的,所以同样的种子会产生同样的随机值
#include<stdlib.h>
#include<stdio.h>
#include<time.h>/*用到了time函数,所以要有这个头文件*/
#define MAX 10
 
int main(void)
{
int number[MAX] = {0};
int i;
srand((unsigned)time(NULL));/*播种子*/
for(i = 0; i < MAX; i++)
{
number[i] = rand() % 100;/*产生100以内的随机整数*/
printf("%d",number[i]);
}
printf("\n");
return 0;
}
注:这个是根据系统时间来产生随机数的,因为每时每刻的时间不一样那么随机数也不一样了
#include<iostream>
#include<ctime>
#include<cstdlib>
using namespace std;
double random(double,double);
 
int main()
{
srand( unsigned( time(0) ) );//srand(time(NULL));
for(int j = 0; j < 10; j++)
cout << "No." << j+1 << ":" << int(random(0,10)) << endl;
return 0;
}
double random(double start,double end)
{
return start + (end - start) * rand() / (RAND_MAX + 1.0);
}
//从此处采取点斜式子,将返回值范围限定至0-9//的整数,倘若要生成10,(RAND_MAX+1.0)改成(RAND_MAX)
/*运行结果
*No.1:3
*No.2:9
*No.3:0
*No.4:9
*No.5:5
*No.6:6
*No.7:9
*No.8:2
*No.9:9
*No.10:6*/
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
#include<stdlib.h>/*用到了srand函数,所以要有这个头文件*/
#include<stdio.h>
#define MAX 10
 
int main(void)
{
int number[MAX] = {0};
int i;
unsigned int seed;
scanf("%d",&seed);/*手动输入种子*/
srand(seed);
for(i = 0; i < MAX; i++)
{
number[i] = rand() % 100;/*产生100以内的随机整数*/
printf("%d",number[i]);
}
printf("\n");
return 0;
}

最新文章

  1. django template
  2. ethtool使用记录
  3. 会吓人的概念证明病毒: Chameleon
  4. C++ Bitsets
  5. c语言学习之基础知识点介绍(三):scanf函数
  6. 【Java】Java网络编程菜鸟进阶:TCP和套接字入门
  7. iOS网络开发-打造自己的视频客户端
  8. underscore.js 源码阅读 一 整体结构
  9. C语言-第一次作业
  10. CSS基础选择器(选择器的优先级),CSS样式块( 长度/颜色/显示方式/文本样式),盒模型组成,盒模型-block,盒模型布局
  11. Go 初体验 - 死锁的几种情况
  12. Weighted Quick Union with Path Compression (WQUPC)
  13. Linux快速目录间切换cd pushd popd
  14. 关于Hive中常用函数需要注意的点小合集
  15. hdu 3861 The King’s Problem trajan缩点+二分图匹配
  16. NoSQLUnit
  17. NOSQL之MONGODB
  18. Appium——unknown error: cannot activate web view
  19. spring mvc:常用标签库(文本框,密码框,文本域,复选框,单选按钮,下拉框隐藏于,上传文件等)
  20. ThinkPHP vendor 方法导入第三方类库

热门文章

  1. AJPFX总结Collection集合(下)
  2. re正则表达式公式讲解6
  3. The Performance Manifesto
  4. x86和i386
  5. (译)IOS block编程指南 1 介绍
  6. 关于JDBC访问存储过程的问题
  7. Linux目录结构及详细介绍
  8. 多表单异步验证 可以用 Promise validate
  9. 第4节 hive调优:动态分区调整问题
  10. spring boot jar的生成