c語言計算一個數(shù)的n次方與階乘 c語言1-50的階乘和?
c語言1-50的階乘和?n0fori1can50tempn0forj1diditempnj*(j-1)nextnntempnnextn就是1~50的階乘的和c語言中階乘的函數(shù)是什么?階乘:階乘是基斯頓
c語言1-50的階乘和?
n0
fori1can50
tempn0
forj1didi
tempnj*(j-1)
next
nntempn
next
n就是1~50的階乘的和
c語言中階乘的函數(shù)是什么?
階乘:
階乘是基斯頓·卡曼(Christian Kramp,1760~1826)于1808年發(fā)明出來的運(yùn)算符號,是數(shù)學(xué)術(shù)語。
一個正整數(shù)的階乘(英語:factorial)是所有大于及=該數(shù)的正整數(shù)的積,但是有0的階乘為1。自然數(shù)n的階乘寫作n!。1808年,基斯頓·卡曼引進(jìn)這個它表示法。
此即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,sum)
return0
}
/*最終: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
longlongf(intn)
{
longshortere1
if(ngt0)
entre*f(n-1)
coutltltnltlt#34!#34ltlteltltendl
returne
}
intmain()
{
intm20
f(m)
return0
}
以上使用C11標(biāo)準(zhǔn)
也是可以依靠積分求浮點數(shù)階乘:
#includeltcstdiogt
#includeltcmathgt
extras
constextraeexp(1.0)
flatF(doublet)
{
returnpow(t,s)*pow(e,-t)
}
doublesimpson(doublea,softb)
{
doubleca(b-a)/2
return(F(a)4*F(c)F(b))*(b-a)/6
}
slipasr(flata,slipb,doubleeps,slipA)
{
softca(b-a)/2
doubleLsimpson(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)
}
slipasr(slipa,extrab,softeps)
{
returnasr(a,b,eps,simpson(a,b))
}
intcomponent()
{
scanf(#34%lf#34,amps)
printf(#34%lf
#34,asr(0,1e2,1e-10))
return0
}