c語言20階乘和
㈠ 用c語言求1~20的階乘之和!
/**
**程序描述:求求1~20的階乘之和。
**演算法思路:先求出每一項的階乘值,然後將所有項的階乘值相加。
*/
#include<stdio.h>
#defineN20
typedefunsignedlonglonguInt64;//自定義類型
//求出每一項階乘值的函數
uInt64fact(intn)
{
inti;
uInt64s;
for(i=s=1;i<=n;i++)
s*=i;//從1開始循環累加相乘
returns;
}
intmain()
{
uInt64s;
inti;
for(i=1,s=0;i<=N;i++)
s+=fact(i);//從第1項開始循環累加每一項的階乘值
printf("1!+2!+3!+……+20!=%llu ",s);
return0;
}
㈡ 1到20階乘的和用c語言表達
#include <stdio.h>
long jiecheng(int x)
{
long int i,k=1;
for(i=1;i<=x;i++)
k=k*i;
return k;
}
int main()
{
long int j,k=0;
int i;
for(i=1;i<=20;i++)
{
j=jiecheng(i);
k+=j;
}
printf("%ld ",k);
}
(2)c語言20階乘和擴展閱讀:
使用其他方法實現求1到20階乘的和:
public class Main{
public static void main(String[] args){
int i,j;
int sum=0;
int a=1;
for(i=1;i<=20;i++){
for(j=1;j<=i;j++){
a*=j;
}
sum+=a;
}
System.out.print("sum=1!+2!+3!+...+20!="+sum);
}
}
㈢ 跪求:編寫c語言程序,求1到20的階乘之和
親測可用
long jiecheng(int x)
{
long int i,k=1;
for(i=1;i<=x;i++)
k=k*i;
return k;
}
int main()
{
long int j,k=0;
int i;
for(i=1;i<=20;i++)
{
j=jiecheng(i);
k+=j;
}
printf("%ld ",k);
}
輸出的結果是2561327494111820313
(3)c語言20階乘和擴展閱讀:
一個正整數的階乘(factorial)是所有小於及等於該數的正整數的積,並且0的階乘為1。自然數n的階乘寫作n!。1808年,基斯頓·卡曼引進這個表示法。
亦即n!=1×2×3×...×n。階乘亦可以遞歸方式定義:0!=1,n!=(n-1)!×n。
計算方法:
大於等於1:
任何大於等於1 的自然數n 階乘表示方法:n! =1×2×3×...×(n-1)n或n! = n×(n-1)!
0的階乘:0!=1。
參考資料:網路——階乘
㈣ c語言1~20階乘只和
#include<stdio.h>
#include<math.h>
intmain()
{
doublejiecheng(intx);//<==================
inta;doublec=0;doubleb;
for(a=1;a<=20;a++)
{
b=jiecheng(a);
c=c+b;
}
printf("%20.15e",c);
return0;
}
doublejiecheng(intx)//<==================
{
inty=1;doublek=1.0;
for(;y<=x;y++)
k=k*y;
return(k);
}
㈤ C語言,算1到20階乘的和
s*=i相當於s=s*i,假如某一次循環中i=k(k代表某個自然數),s=S那麼執行完s*=i後s=S*k;下一次循環時i=k+1,執行完s*=i後s=S*k*(k+1)。而初始情況是i=1,s=1,根據數學歸納法可以推導出s中保存的值是1*2*...*(k+1)。
㈥ C語言輸出20之內的階乘之和代碼
#include<stdio.h>
intmain(){
__int64fact=1,i,sum=0;
for(i=1;i<21;++i){
fact*=i;
sum+=fact;
}
printf("sum=%I64d ",sum);
return0;
}
類型必須設置為__int64 或者long long 否則會溢出
你的代碼就是這樣 會溢出的
㈦ c語言計算1到20的階乘的和,我的代碼哪錯了
在32偉環境下,20的階乘已經超出int的范圍,而i是個int,必然會溢出,結果就是錯誤的
把i定義成double就行了
#include<stdio.h>
main()
{
intn=0;
doublei=1.0;//double
doublesum=0;
for(n=0;n<20;n++)
{
i=i*(n+1);
sum=sum+i;
}
printf("sum=%lf ",i);
return0;
}
㈧ 利用C語言求階乘 例如求20! 用循環和函數兩種方法……
對於階乘,你需要考慮到輸入的數的大小,進行判斷n<0,無階乘;n==0||n==1階乘為1;
n>1的就用戶循環,或者調用函數來做
1.循環
#include<stdio.h>
void main()
{
float sum=1;
int n,i;
printf("please enter an integer number:");
scanf("%d",&n);
printf("\n");
if (n<0)
printf("n<0,data error!\n");
else if(n>1)
{
for(i=2;i<=n;i++)
sum=sum*i;
printf("%d!=%10.0f\n",n,sum);
}
else
if(n==0||n==1)
{
sum=1;
printf("%d!=%10.0f\n",n,sum);
}
}
2.函數
#include <stdio.h>
void main()
{
float fac(int n);
int n;
float y;
printf("input an integer number:");
scanf("%d",&n);
y=fac(n);
printf("%d!=%10.0f\n",n,y);
}
float fac(int n)
{
float f;
if(n<0)
{
printf("n<0,data error");
}
else
if(n==0||n==1)
f=1;
else
f=fac(n-1)*n;
return (f);
}
㈨ c語言 1到20的階乘之和
/**
**程序描述:求求1~20的階乘之和。
**演算法思路:先求出每一項的階乘值,然後將所有項的階乘值相加。
*/
#include<stdio.h>
#defineN20
typedefunsignedlonglonguInt64;//自定義類型
//求出每一項階乘值的函數
uInt64fact(intn)
{
inti;
uInt64s;
for(i=s=1;i<=n;i++)
s*=i;//從1開始循環累加相乘
returns;
}
intmain()
{
uInt64s;
inti;
for(i=1,s=0;i<=N;i++)
s+=fact(i);//從第1項開始循環累加每一項的階乘值
printf("1!+2!+3!+……+20!=%llu ",s);
return0;
}