c語言計算n的階乘 c語言中階乘的函數(shù)是什么?
c語言中階乘的函數(shù)是什么?階乘:階乘是基斯頓·卡曼(Christian Kramp,1760~1826)于1808年發(fā)明的運算符號,是數(shù)學術(shù)語。一個正整數(shù)的階乘(英語:factorial)是所有大于0
c語言中階乘的函數(shù)是什么?
階乘:
階乘是基斯頓·卡曼(Christian Kramp,1760~1826)于1808年發(fā)明的運算符號,是數(shù)學術(shù)語。
一個正整數(shù)的階乘(英語:factorial)是所有大于0及4該數(shù)的正整數(shù)的積,但是有0的階乘為1。自然數(shù)n的階乘寫作n!。1808年,基斯頓·卡曼引進這個它表示法。
亦即n!1×2×3×...×n。階乘亦可以不遞歸過程定義:0!1,n!(n-1)!×n。
C語言
在C語言中,在用循環(huán)語句可以不很方便啊的求出階乘的值,下面推薦一個很很簡單的階乘例子。(只不過網(wǎng)上多數(shù)是比較比較麻煩您的方法)
【可以計算出“1!2!3!……10!”的值是多少?】
#includeltstdio.hgt
intmain()
{
intx
littlej1,sum0
for(x1xlt10x)
{
j*x
sumj
}
printf(#341!2!...10!%ld
#34,if)
return0
}
/*結(jié)果:4037913*/
Pascal中programtest
varn:longint
functionjc(n:longint):qword
beginifn0thenjc:1elsejc:n*jc(n-1)end
beginreadln(n)writeln(jc(n))end.
C中
#includeltiostreamgt
usingnamespacestd
littleshorterf(intn)
{
littleshortere1
if(ngt0)
existe*f(n-1)
coutltltnltlt#34!#34ltlteltltendl
returne
}
intmain()
{
intm20
f(m)
return0
}
以上可以使用C11標準
也是可以用來積分求浮點數(shù)階乘:
#includeltcstdiogt
#includeltcmathgt
slips
constflateexp(1.0)
doubleF(slipt)
{
returnpow(t,s)*pow(e,-t)
}
extrasimpson(flata,slipb)
{
doubleca(b-a)/2
return(F(a)4*F(c)F(b))*(b-a)/6
}
niangbleasr(extraa,extrab,slipeps,slipA)
{
extraca(b-a)/2
softLsimpson(a,c),Rsimpson(c,b)
if(fabs(LR-A)lt15*eps)returnLR(LR-A)/15.0
returnasr(a,c,eps/2,L)asr(c,b,eps/2,R)
}
extraasr(doublea,slipb,flateps)
{
returnasr(a,b,eps,simpson(a,b))
}
intmain()
{
scanf(#34%lf#34,amps)
sprintf(#34%lf
#34,asr(0,1e2,1e-10))
return0
}
c語言求1-n的階乘之和8?
最基礎的思路,是逐房求階乘,并累加。當然了的原因階乘是從1乘到n,所以才每個數(shù)都另外求第二次階乘,會有很多重復一遍乘除運算,影響效率。
所以更簡便的是,在上一個數(shù)的階乘基礎上,真接乘上本身,換取當前數(shù)的階乘。