如何用c语言产生一定范围内的随机数?
利用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语言中如何产生10到100的随机数
包含以下库
#include stdlib.h
先调用初始化随机数
void srand(unsigned seed);
再调用
rand() 得到随机数
rand()%91 + 10 就是 10 到100的随机数
C语言如何srand和rand函数产生10个1-100内的随机数知道
先用srand函数设置一个种子,一般为当前时间,然后使用rand函数产生随机数,如产生a~b的随机数使用表达式rand()%(b-a+1)+a。
注意:srand函数在头文件#include
stdlib.h中。
示例代码:
#include stdio.h
#include stdlib.h
#include time.h
int main()
{
int a[10]/*用于保存10个产生的随机数*/, i;
srand((unsigned int)time(NULL));//设置当前时间为种子
for (i = 0; i 10; ++i){
a[i] = rand()%100+1;//产生1~100的随机数
}
//打印生成的随机数
for (i = 0; i 10; ++i){
printf (“%d “, a[i]);
}
printf (“\n”);
return 0;
}
c语言怎么写1到100中随机数啊?
包含头文件stdlib.h,产生的随机数为rand()%100+1,用一个变量保存这个随机数就行,当然也还有比较复杂和完善的产生随机数的方法,不过这个是最简单的
你好,怎样用c语言输出一个1到100的随机数
源程序如下:
#include “pch.h”
#include iostream
#include time.h
using namespace std;
int main()
{
const int n = 10000;
int number[n] = { NULL };
srand((unsigned)time(NULL));
number[0] = rand() % n; //第一个随机数无需比较
cout number[0] ” “;
for (int i = 1; i n; i++) //其余随机数循环产生
{
int j = 0;
number[i] = rand() % n;
while (1)
{
if (number[i] == number[j]) //若有相同则继续循环重新安排随机数
{
number[i] = rand() % n;
j = 0; //若遇到相同的就从头遍历
continue;
}
if (j == (i – 1)) //若遍历完就跳出
break;
j++;
}
cout number[i] ” “;
}
cout endl;
return 0;
}
程序运行结果:
扩展资料:
其他实现方式:
#includetime.h //使用 time 函数必须引入 time.h 头文件
#includestdlib.h
int main()
{
srand((int)time(0));
int rand_num = rand();
printf(“rand_num = %d\n”, rand_num);
return 0;
}