當前位置:首頁 » 編程語言 » c語言階層加

c語言階層加

發布時間: 2022-05-19 05:36:40

c語言 階乘想加

#include<stdio.h>
voidmain(){
inti,n,k=1,s=0;
scanf("%d",&n);
for(i=1;i<=n;i++)
{k*=i;s+=k;}
printf("%d",s);
}

//運行示例:

㈡ 階乘相加的問題C語言

main()
{
int i,sum=0;
for(i=1;i<=4;i++)
{
int temp=1;
for(int j=i;j>=1;j--)
{
temp=temp*j;
}
sum=sum+temp;
}
printf("%d",sum);

}

還可以用遞歸來實現的,方法很多種!具體自己找書來看吧,這些都是基礎!!

㈢ 用c語言編程,求從1的階乘一直加到20的階乘。

1、首先打開C語言編輯器,新建一個c語言的文件,導入頭文件並設置一個主函數:

㈣ 用C語言 從一的階乘加到二十的階乘

1、找到文件,新建,項目,點擊項目新建一個文件。

㈤ c語言 使任意三個數的階乘相加

#include<stdio.h>
void main()
{
long int jies(int a);
long int k,l,m;
printf("輸入要求階乘的三個數,用空格隔開\n");
scanf("%d%d%d",&k,&l,&m);
long int sum;
sum=jies(k)+jies(l)+jies(m);
printf("sum=%d\n",sum);
}
long int jies(int a)
{
long int j;
if(a<0)
printf("輸入有誤");
else if(a==1||a==0)
return 1;
else
j=a*jies(a-1);//遞歸演算法
return j;
}

㈥ c語言1階層加到10階層怎麼寫,我還是菜鳥

先寫一個求階乘的函數
long getSum(int s)
{
if(s==0)
return 1;
long m = 1;
for (int i = 1; i <= s; i++)
{
m *= i;
}
return m;
}
然後再主函數里
long result=0;
for(int i=1; i<=10; i++)
{
result+=getSum(i);
}
//result即為結果

㈦ c語言編寫 階乘累加

#include<stdio.h>
long cal(int i)
{
long s;
int j;
for(j=1,s=1;j<=i;j++)
s=s*j;
return s;
}
main()
{
int i;
long sum=0;
for(i=1;i<=3;i++)
sum+=cal(i);
printf("%d\n",sum);
}
這個是c語言編程的程序,我已經在vc裡面通過調試了,1樓的好像寫的c++的程序吧

㈧ c語言求階乘累加和

題目中數據很大

於是我們有了高精度演算法

思路是什麼呢:

一個數組裡面每一位存的是十進制數三位(也可以只存一位,但是比較慢)

也可以理解成一千進制

這樣能模擬大整數的乘法、加法

#include<stdio.h>
#include<string.h>
#definemax(a,b)(a>b?a:b)
intn;
FILE*input,*output;
structbigint
{
intlen;
intnum[1100];
}fac,sum;
voidmul(intvalue){//高精度乘單精度
inti;
for(i=1;i<=fac.len;i++)
fac.num[i]=fac.num[i]*value;//每個數位乘上數
for(i=1;i<=fac.len;i++)
if(fac.num[i]>=1000){//逢千進一
fac.num[i+1]+=fac.num[i]/1000;fac.num[i]%=1000;
}
if(fac.num[fac.len+1])fac.len++;//位數可能會增加,而且最多增加1
}
voidadd()//給sum加上fac的值
{
inti;
//由於此時fac永遠大於sum所以不用判斷sum的長度
for(i=1;i<=fac.len;i++)
sum.num[i]+=fac.num[i];//每一位加上fac的值
for(i=1;i<=fac.len;i++)
if(sum.num[i]>=1000){//逢千進一
sum.num[i+1]++;sum.num[i]-=1000;//因為加法運算不可能往前進2
}
sum.len=fac.len;
if(sum.num[sum.len+1])sum.len++;
}
voidout()//輸出
{
inti;
for(i=sum.len;i>=1;i--)
{
if(i<sum.len)//壓位高精度一定要判斷位數
{//因為如果不是第一位,其他要補0,因為如果這個數是1001,就會變成11
if(sum.num[i]<10)fprintf(output,"00");
elseif(sum.num[i]<100)fprintf(output,"0");
}
fprintf(output,"%d",sum.num[i]);
}
fputc(' ',output);
}
intmain(){
input=fopen("factor.in","r");
output=fopen("factor.out","w");
memset(fac.num,0,sizeoffac.num);
memset(sum.num,0,sizeofsum.num);
fscanf(input,"%d",&n);
inti;
fac.len=sum.len=1;//初始賦成1
fac.num[1]=sum.num[1]=1;
for(i=2;i<=n;i++)
{
mul(i);
add();
}
out();
fclose(input);fclose(output);
return0;
}

㈨ C語言中階乘相加

#include<stdio.h>
main()
{
int a;
double b=1,c=1,d=0;
printf("\nplease input a number\n");
scanf("%d",&a);
for(;b<a;++b); /*這里的for(;b<a;++b); 分號要去掉:b<=a;
就是說你輸入3的話,只有1*2,應該是1*2*3,其他沒任何問題*/
{
c=c*b;
d+=c;
}
printf("\n%f",d);
}
/*這里的for(;b<a;++b); 分號要去掉:b<=a;
就是說你輸入3的話,只有1*2,應該是1*2*3,其他沒任何問題*/

㈩ 用C語言求1到N的階層 的累加和

思路:先定義一個函數用來計算一個數的階乘,在從1到N循環依次就其累加和,最後輸出累加和即可。
參考代碼:例如求1到3的階乘累加和。
#include "stdio.h"
int fun(int n){
if(n==1) return 1;
else return n*fun(n-1);
}
#include "math.h"
int main() {
int n,sum=0,i;
scanf("%d",&n);
for(i=1;i<=n;i++)
sum+=fun(i);
printf("%d\n",sum);

return 0;
}
/*
運行結果:
3
9
*/

熱點內容
我的世界哪五個伺服器被炸了 發布:2025-05-15 10:36:16 瀏覽:993
ehcache存儲對象 發布:2025-05-15 10:35:31 瀏覽:526
搭建虛擬電腦的伺服器 發布:2025-05-15 10:29:31 瀏覽:269
湖人雙核配置哪個最好 發布:2025-05-15 10:09:48 瀏覽:979
手機熱點密碼怎麼查看 發布:2025-05-15 09:54:47 瀏覽:108
生意發力雲存儲 發布:2025-05-15 09:54:45 瀏覽:616
編寫一個shell腳本添加用戶 發布:2025-05-15 09:54:43 瀏覽:505
資料庫查看錶命令 發布:2025-05-15 09:52:27 瀏覽:914
p30是不是自帶方舟編譯器 發布:2025-05-15 09:51:48 瀏覽:599
追擊世界房間密碼是多少 發布:2025-05-15 09:51:46 瀏覽:995