c语言标准正态函数 c语言产生正态分布随机数

C语言中的标准函数有哪些在最新的 C99 标准中,只有以下两种定义方式是正确的:
int main( void )/* 无参数形式 */
{
return 0;
}
int main( int argc, char *argv[] ) /* 带参数形式 */
{
return 0;
}
int指明了main()函数的返回类型,函数名后面的圆括号一般包含传递给函数的信息 。void表示没有给函数传递参数 。关于带参数的形式,我们等会讨论 。
浏览老版本的C代码,将会发现程序常常以 。
main()
这种形式开始 。C90标准允许这种形式,但是C99标准不允许 。因此即使你当前的编译器允许,也不要这么写 。
你还可能看到过另一种形式 。
void main()
有些编译器允许这种形式,但是还没有任何标准考虑接受它 。C之父 Bjarne Stroustrup 在他的主页上的 FAQ 中明确地表示:void main( ) 的定义从来就不存在于 C或者 C。所以,编译器不必接受这种形式,并且很多编译器也不允许这么写 。
如何用C语言生成一个正态分布的样本调试程序时,随机数种子可以设常数 , 例如srand(54321);
用 rand() 产生均匀分布随机数x1,x2
利用瑞利分布得正态分布随机数 y1,y2
再按要求线性缩放一下到[0.01,2] 区间 。
#include stdio.h
#include stdlib.h
#include math.h
#include time.h
main(){
#define N 100
double rd[N];
【c语言标准正态函数 c语言产生正态分布随机数】double x1,x2,y1,y2;
double pi2=6.28318530728,mx,mi,ave=0;
int i;
//srand(54321);
srand(time(NULL));
for (i=0;i=N-2;i=i 2){
x1=1.0*rand()/RAND_MAX;
x2=1.0*rand()/RAND_MAX;
y1= sqrt((-2.0*log(x1))) * cos(pi2*x2);
y2= sqrt((-2.0*log(x1))) * sin(pi2*x2);
rd[i]=y1;
rd[i 1]=y2;
}
mx=rd[0];mi=rd[0];
for (i=0;iN;i){
if (rd[i]mx)mx=rd[i];
if (rd[i]mi)mi=rd[i];
}
//printf("mi=%lf mx=%lf\n",mi,mx);
for (i=0;iN;i) rd[i] = (rd[i]-mi)/(mx-mi 0.001) * (2.0-0.01)0.01;
for (i=0;iN-2;i=i 2) printf("%lf %lf\n",rd[i],rd[i 1]);
return 0;
}
C语言中的标准函数有哪些?C语言输入输出函数有很多c语言标准正态函数 , 标准I/O函数中包含了如下几个常用c语言标准正态函数的函数:
scanf,printf,getc,putc,getchar,putchar,gets,puts,fgets,fputs,fgetc,fputc,fscanf,fprintf等.
int
getc(FILE
*fp)
getc主要是从文件中读出一个字符.常用的判断文件是否读取结束的语句为
(ch
=
getc(fp))
!=
EOF.EOF为文件结束标志,定义在stdio.h中,就像EXIT_SUCCESS,EXIT_FAILURE定义在stdlib.h中一样,文件也可以被理解为一种流,所以当fp为stdin时,getc(stdin)就等同于getchar()了.
int
putc(int
ch,FILE
*fp)
putc主要是把字符ch写到文件fp中去.如果fp为stdout,则putc就等同于putchar()了.
int
getchar(void)
getchar主要是从标准输入流读取一个字符.默认的标准输入流即stdio.h中定义的stdin.但是从输入流中读取字符时又涉及到缓冲的问题,所以并不是在屏幕中敲上一个字符程序就会运行,一般是通过在屏幕上敲上回车键,然后将回车前的字符串放在缓冲区中,getchar就是在缓冲区中一个一个的读字符.当然也可以在while循环中指定终止字符,如下面的语句:while
((c
=
getchar())
!=
'#')这是以#来结束的.
int
putchar(int
ch)
putchar(ch)主要是把字符ch写到标准流stdout中去.
char
*
gets(char
*str)
gets主要是从标准输入流读取字符串并回显,读到换行符时退出,并会将换行符省去.
int
puts(char
*str)
puts主要是把字符串str写到标准流stdout中去,并会在输出到最后时添加一个换行符.
char
*fgets(char
*str,
int
num,
FILE
*fp)
str是存放读入的字符数组指针,num是最大允许的读入字符数,fp是文件指针.fgets的功能是读一行字符,该行的字符数不大于num-1.因为fgets函数会在末尾加上一个空字符以构成一个字符串.另外fgets在读取到换行符后不会将其省略.
int
fputs(char
*str,
file
*fp)
fputs将str写入fp.fputs与puts的不同之处是fputs在打印时并不添加换行符.
int
fgetc(FILE
*fp)
fgetc从fp的当前位置读取一个字符.
int
fputc(int
ch,
file
*fp)
fputc是将ch写入fp当前指定位置.
int
fscanf(FILE
*fp,
char
*format,
输入列表)
fscanf按照指定格式从文件中出读出数据,并赋值到参数列表中.
int
fprintf(FILE
*fp,
char
*format,
输出列表)
fprintf将格式化数据写入流式文件中.
数据块读写函数
fread
(buffer,size,count , fp);
fwrite(buffer,size,count,fp);
参数说明:
buffer:是一个指针 。
对fread
来说,它是读入数据的存放地址 。
对fwrite来说,是要输出数据的地址(均指起始地址) 。
size:
要读写的字节数 。
count:
要进行读写多少个size字节的数据项 。
fp:
文件型指针 。
怎么调用c语言中的标准正态分布函数?摘要c语言标准正态函数:
随机数在实际运用中非常之多c语言标准正态函数 , 如游戏设计,信号处理,通常我们很容易得到平均分布c语言标准正态函数的随机数 。但如何根据平均分布的随机数进而产生其它分布的随机数呢?本文提出了一种基于几何直观面积的方法,以正态分布随机数的产生为例讨论了任意分布的随机数的产生方法 。
大家都知道,随机数在各个方面都有很大的作用,在vc的环境下,为我们提供了库函数rand()来产生一个随机的整数 。该随机数是平均在0~RAND_MAX之间平均分布的,RAND_MAX是一个常量,在VC6.0环境下是这样定义的:
#define RAND_MAX 0x7fff
它是一个short 型数据的最大值,如果要产生一个浮点型的随机数,可以将rand()/1000.0这样就得到一个0~32.767之间平均分布的随机浮点数 。如果要使得范围大一点,那么可以通过产生几个随机数的线性组合来实现任意范围内的平均分布的随机数 。例如要产生-1000~1000之间的精度为四位小数的平均分布的随机数可以这样来实现 。先产生一个0到10000之间的随机整数 。方法如下 :
int a = rand()000;
然后保留四位小数产生0~1之间的随机小数:
double b = (double)a/10000.0;
然后通过线性组合就可以实现任意范围内的随机数的产生,要实现-1000~1000内的平均分布的随机数可以这样做:
double dValue = https://www.04ip.com/post/(rand()000)/10000.0*1000-(rand()000)/10000.0*1000;
则dValue就是所要的值 。
到现在为止,你或许以为一切工作都已经完成了,其实不然,仔细一看,你会发现有问题的,上面的式子化简后就变为:
double dValue = https://www.04ip.com/post/(rand()000)/10.0-(rand()000)/10.0;
这样一来,产生的随机数范围是正确的,但是精度不正确了 , 变成了只有一位正确的小数的随机数了,后面三位的小数都是零 , 显然不是我们要求的,什么原因呢,又怎么办呢 。
先找原因,rand()产生的随机数分辨率为32767,两个就是65534 , 而经过求余后分辨度还要减小为10000,两个就是20000而要求的分辨率为1000*10000*2=20000000,显然远远不够 。下面提供的方法可以实现正确的结果:
double a = (rand()000) * (rand()00)/10000.0;
double b = (rand()000) * (rand()00)/10000.0;
double dValue = https://www.04ip.com/post/a-b;
则dValue就是所要求的结果 。在下面的函数中可以实现产生一个在一个区间之内的平均分布的随机数,精度是4位小数 。
double AverageRandom(double min,double max)
{
int minInteger = (int)(min*10000);
int maxInteger = (int)(max*10000);
int randInteger = rand()*rand();
int diffInteger = maxInteger - minInteger;
int resultInteger = randInteger % diffIntegerminInteger;
return resultInteger/10000.0;
}
但是有一个值得注意的问题,随机数的产生需要有一个随机的种子 , 因为用计算机产生的随机数是通过递推的方法得来的,必须有一个初始值,也就是通常所说的随机种子,如果不对随机种子进行初始化 , 那么计算机有一个确省的随机种子,这样每次递推的结果就完全相同了,因此需要在每次程序运行时对随机种子进行初始化,在vc中的方法是调用srand(int)这个函数 , 其参数就是随机种子,但是如果给一个常量 , 则得到的随机序列就完全相同了,因此可以使用系统的时间来作为随机种子,因为系统时间可以保证它的随机性 。
调用方法是srand(GetTickCount()),但是又不能在每次调用rand()的时候都用srand(GetTickCount())来初始化,因为现在计算机运行时间比较快,当连续调用rand()时,系统的时间还没有更新,所以得到的随机种子在一段时间内是完全相同的 , 因此一般只在进行一次大批随机数产生之前进行一次随机种子的初始化 。下面的代码产生了400个在-1~1之间的平均分布的随机数 。
double dValue[400];
srand(GetTickCount());
for(int i= 0;i400; i)
{
double dValue[i] = AverageRandom(-1,1);
}
标准正态分布函数的c语言代码 谢啦double gaussian(double u)//用Box_Muller算法产生高斯分布c语言标准正态函数的随机数
{
double r,t,z,x;
double s1,s2;
s1=(1.0 rand())/(RAND_MAX 1.0);
s2=(1.0 rand())/(RAND_MAX 1.0);
r=sqrt(-2*log(s2)/log(e));
t=2*pi*s1;
z=r*cos(t);
x=u z*N;
return x;
}
以前写c语言标准正态函数的一个函数c语言标准正态函数,u是均值c语言标准正态函数,N是方差
请问:C语言中怎么计算正态分布函数?C语言中计算一个数的N次方可以用库函数pow来实现 。
函数原型:double pow(double x, double y);
功能:计算x^y的值
返 回值:计算结果
举例如下:
double a = pow(3.14, 2);// 计算3.14的平方
注:使用pow函数时,需要将头文件#includemath.h包含进源文件中 。
c语言标准正态函数的介绍就聊到这里吧 , 感谢你花时间阅读本站内容,更多关于c语言产生正态分布随机数、c语言标准正态函数的信息别忘了在本站进行查找喔 。

    推荐阅读