用C语言怎样求阶乘之和? 思路 编个函数求n的阶乘的
创新互联建站主营泌阳网站建设的网络公司,主营网站建设方案,APP应用开发,泌阳h5小程序制作搭建,泌阳网站营销推广欢迎泌阳等地区企业咨询
递归方法
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;i200;i++)
f[i]*=j;
进位
for(i=0;i199;i++)
{
f[i+1]+=f[i]/10;
f[i]%=10;
}
add to sum
for(i=0;i200;i++)
sum[i]+=f[i];
sum进位
for(i=0;i199;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.hint 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求和:
#includestdio.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!
阶乘:
阶乘是基斯顿·卡曼(Christian
Kramp,1760~1826)于
1808
年发明的运算符号,是数学术语。
一个正整数的阶乘(英语:factorial)是所有小于及等于该数的正整数的积,并且有0的阶乘为1。自然数n的阶乘写作n!。1808年,基斯顿·卡曼引进这个表示法。
亦即n!=1×2×3×...×n。阶乘亦可以递归方式定义:0!=1,n!=(n-1)!×n。
C语言
在
C
语言中,使用循环语句可以很方便的求出阶乘的值,下面介绍一个很简单的阶乘例子。(因为网上多数是比较麻烦的方法)
【计算出“
1!+
2!+
3!+
……
+
10!”的值是多少?】
#includestdio.h
int
main()
{
int
x;
long
j=1,sum=0;
for(x=1;x=10;x++)
{
j*=x;
sum+=j;
}
printf("1!+2!+...+10!=%ld\n",sum);
return
0;
}
/*结果:4037913*/
Pascal中program
test;
varn:longint;
function
jc(n:longint):qword;
begin
if
n=0
then
jc:=1
else
jc:=n*jc(n-1)end;
begin
readln
(n);
writeln
(jc(n))end.
C++
中
#includeiostream
using
namespace
std;
long
long
f(int
n)
{
long
long
e=1;
if(n0)
e=n*f(n-1);
coutn"!="eendl;
return
e;
}
int
main()
{
int
m=20;
f(m);
return
0;
}
以上使用
C++
11
标准
也可以利用积分求浮点数阶乘:
#includecstdio
#includecmath
double
s;
const
double
e=exp(1.0);
double
F(double
t)
{
return
pow(t,s)*pow(e,-t);
}
double
simpson(double
a,double
b)
{
double
c=a+(b-a)/2;
return
(F(a)+4*F(c)+F(b))*(b-a)/6;
}
double
asr(double
a,double
b,double
eps,double
A)
{
double
c=a+(b-a)/2;
double
L=simpson(a,c),R=simpson(c,b);
if(fabs(L+R-A)=15*eps)
return
L+R+(L+R-A)/15.0;
return
asr(a,c,eps/2,L)+asr(c,b,eps/2,R);
}
double
asr(double
a,double
b,double
eps)
{
return
asr(a,b,eps,simpson(a,b));
}
int
main()
{
scanf("%lf",s);
printf("%lf\n",asr(0,1e2,1e-10));
return
0;
}
fun(int i)
{
int j;
int sum=0;
for(j=1;j=i;j++)
{
sum=sum+j*j;
}
printf("s%d=%d\n",j,sum);
return sum;
}
//上面的代码是求平方和
//求阶乘可以这样:
int fun(int i)//返回类型不可少
{
int j;
int sum=1;//从1开始
for(j=1;j=i;j++)
{
sum=sum * j;
}
printf("s%d=%d\n",j,sum);
return sum;
}
//主函数中是求阶乘的和
法/步骤
第一步、编程的第一步就是写头文件,对于初学者来说,只写一个头文件就可以了,即#includestdio.h
第二步、就是定义我们的变量,我们需要定义一个n,用来求他的阶乘,sum用来保存结果,i用来循环
第三步、就是把sum初始化,为1.千万不要为0,保证后面的结果不出问题。
第四步、就是输入一个n,用来求n的阶乘,别忘了在前面提示一下。
第五步、就是利用for循环来求阶乘。
第六步、就是调用printf(:);函数来输出阶乘结果。
拓展资料
定义
n!=1×2×3...xn
n!=X×(X-1)×(X-2)...×1
1751年,欧拉以大写字母M表示m阶乘 M=1x2x3...x...m
1799年,鲁非尼在他出版的方程论著述中,则以小写字母π表示m阶乘。而在1813年,高斯则以Π(n)来表示n阶乘。而用来表示n阶乘的方法起源于英国,但仍未能确定始创人是谁。直至1827年,由于雅莱特的建议而得到流行,现在有时也会以这个符号作为阶乘符号。
当n较大时,直接计算n!变得不可能,这时可通过斯特灵(Stirling)公式计算近似算或取得大小范围。