❶ 用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;
}
❷ 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语言编程,求从1的阶乘一直加到20的阶乘。
1、首先打开C语言编辑器,新建一个c语言的文件,导入头文件并设置一个主函数:
❹ c语言求1到n的阶乘的和
最基础的思路,是逐个求阶乘,并累加。不过由于阶乘是从1乘到n,所以每个数都单独求一次阶乘,会有很多重复运算,影响效率。
所以更快捷的方式是,在上一个数的阶乘基础上,直接乘上本身,得到当前数的阶乘。
以此为主导,代码如下:
#include <stdio.h>
int main()
{
int n, i, n1 = 1,s=0;
scanf("%d",&n);//输入n值。
for(i=1; i <= n; i ++)
{
n1*=i;//计算i的阶乘。
s+=n1;//累加。
}
printf("%d\n", s);//输出结果。
}
❺ 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,其他没任何问题*/
❻ 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);
}
(6)求c语言阶乘相加扩展阅读:
使用其他方法实现求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到100的阶乘和
操作方法01
首先打开Dev C++软件,新建C语言控制台项目,如下图所示
❽ C语言怎么求n阶乘的和
1
思路
关键是写出求阶乘的函数
2
代码
#include<stdio.h>
//求阶乘
intfactorial(intn){
if(n==0||n==1)
return1;
else
returnn*factorial(n-1);
}
intmain(){
intn;
printf("求1!+2!+...+n!的结果
输入n的值:");
scanf("%d",&n);
intsum=0;
for(inti=1;i<=n;i++){
sum+=factorial(i);
}
printf("结果为:%d
",sum);
getchar();
getchar();
return0;
}
3
运行效果
❾ 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语言怎样求阶乘之和
用C语言怎样求阶乘之和? 思路 编个函数求n的阶乘的
递归方法
int f(int n){
if(n==1) return 1;
else return n*f(n-1);
}
再在主方法里面编个循环求阶乘之和
int sum=0;
for(i=1;i<=n;i++){
sum=sum+f(i);
}
怎样用C语言求500000的阶乘?
先写两个大数相乘的函数,为了提高效率,定义的数组每个存9位,一个个乘时间肯定是不够的,最好这样比如说先求250 000个积,再用这些积求125 000个积,。。。用空间换取时间
就差不多了
C语言用"for"怎么算1~20!阶乘之和啊?
回答的都很好~
c语言:1到100的阶乘之和,100用N输入
#include <stdio.h>
#include <stdlib.h>
#define MAX 200
int f[MAX]={0},sum[MAX]={0};大整数,每个int存一个十进制数字,从低位到高位
void main(void)
{
int i,j,n;
f[0]=1;
printf("Input N: ");
scanf("%d",&n);输入N
for(j=1;j<=n;j++)
{
calc factorial,每位乘j
for(i=0;i<200;i++)
f[i]*=j;
进位
for(i=0;i<199;i++)
{
f[i+1]+=f[i]/10;
f[i]%=10;
}
add to sum
for(i=0;i<200;i++)
sum[i]+=f[i];
sum进位
for(i=0;i<199;i++)
{
sum[i+1]+=sum[i]/10;
sum[i]%=10;
}
}
从最高位开始输出
先找到最高位
printf("\n\nThe result is:\n");
i=199;
while(sum[i]==0)
i--;
while(i>=0)
printf("%d",sum[i--]);
system("pause");
}
用c语言怎样编1到10的阶乘和
用循环
int sum=1;
for(int i=1;i<=10;i++)
sum=sum*i;
或者用递归函数,可能你还没有学
C语言怎么求0 2 4 6 .2n的阶乘之和啊
#include <stdio.h>求n!的值int func(int n){ if(n == 0 || n==1) return 1; else return n*func(n-1);}int main(){ int n,i,sum=0; printf("输入n的值: "); scanf("%d",&n); if(n<=0) { printf("Input Error!\n"); return -1; } for(i=0;i<=n;i++) { sum+=func(2*i); } printf("0!+2!+4!+...+(2n)!= %d\n",sum); return 0;} 示例运行结果:
输入n的值: 3
0!+2!+4!+...+(2n)!= 747
输入n的值: 2
0!+2!+4!+...+(2n)!= 27
c语言程序设计求一的阶乘,三的阶乘,五的阶乘之和
#include <stdio.h>int fac(int n);int main(){ int sum = 0; sum = fac(1) + fac(3) + fac(5); printf("%d",sum); return 0;}int fac(int n){ int i = 0; int sum = 0; for(; i<=n; i++) sum += i; return sum;}
帮我用c语言编个求两个阶乘之和的程序
int GetN(int x)
{
if(x=1)
return x;
else
return x*GetN(--X);
}
main()
{
int a,b;
Scanf("%d",&a);
Scanf("%d",%b);
printf("%d",GetN(a)+GetN(b));
}
c语言阶乘用循环句两个for怎样求和?
输入以下程序可实现两个for求和:
#include<stdio.h>
void main()
{
int sum=0,n,m=1,i,j;
scanf("%d",&n);
for(i=1;i<=n;i++)
{
for(j=1,m=1;j<=i;j++)
m*=j;
sum+=m;
}
printf("n的阶乘=%d\n",sum);
}
急求C语言阶乘的和
#include "stdio.h"
main()
{
int i,j,sum1,sum=0,n;
printf("请输入n:\n");
scanf("%d",&n);
for(i=1;i<=n;i++)
{
sum1=1;
for(j=1;j<=i;j++)
{
sum1=sum1*j;
}
sum=sum+sum1;
}
if(n==0) sum=1;
printf("\n阶乘的和为:%d",sum);
}
内层for语句是求i的阶乘,外层for语句是求0!+1!+……+n!