A. 用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!
B. 【在线等】c语言程序:对n的阶乘求和,n=1到10
分析下程序,阶乘可以用递归做,也可以用循环做,这里就放上这两种代码了。
一.递归:
#include <stdio.h>
int f(int t)
{
if (t==1)
return 1;
else
return t*f(t-1);
}
int main()
{
printf("%d ",f(10));
return 0;
}
程序分析:定义一个f函数,利用递归的特性,进行运算
10*f(9) = 10*9*f(8) …… 直到到1时返回1
得出结果:
C. C语言问题:阶乘之和
#include<stdio.h>
intfun(intn)
{
inti,k=1;
for(i=1;i<=n;i++)
k*=i;
returnk;
k=1;
}
voidmain()
{
inti,m,n,s=0;
scanf("%d%d",&m,&n);
for(i=m;i<=n;i++)
s+=fun(i);
printf("%d",s);
}
D. C语言 编写程序,从键盘上输入两个数,求这两个数的阶乘和。
java语言编写如下:
packagecom.sxl.test;
importjava.util.Scanner;
publicclassTest{
publicstaticvoidmain(String[]args){
System.out.println("请数入第一个数:");
Scannerinput_a=newScanner(System.in);
inta=input_a.nextInt();
System.out.println("请输入第二个数:");
Scannerinput_b=newScanner(System.in);
intb=input_b.nextInt();
System.out.println(a+"的阶乘加上"+b+"的阶乘="+(fun2(a)+fun2(b)));
}
privatestaticintfun2(inta){
intresult;
if(a<=1){
result=1;
}else{
result=a*fun2(a-1);
}
returnresult;
}
}
c语言的编译器没有安装。但是算法和思路是一样的。
E. 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
运行效果
F. 怎样用C语言计算1到10的阶层的和
C语言中实现阶乘的计算可以采用递归或者循环,通常循环用的比较多,循环可以采用while循环和for循环等。
下面以for循环为例实现1-10的阶乘的和的计算,代码如下:
int i,sum=1,S=0;
for(i=1;i<=10;i++)
{
sum=sum*i;
S=S+sum;
}
上述的变量S在运行结束后的结果值即为1-10的阶乘的和。
(6)c语言两数的阶乘之和扩展阅读:
数学函数
所在函数库为math.h、stdio.h、string.h、float.h
int abs(int i) 返回整型参数i的绝对值
double atof(char *nptr) 将字符串nptr转换成浮点数并返回这个浮点数
double atoi(char *nptr) 将字符串nptr转换成整数并返回这个整数
double atol(char *nptr) 将字符串nptr转换成长整数并返回这个整数
char *ecvt(double value,int ndigit,int *decpt,int *sign),将浮点数value转换成字符串并返回该字符串
G. 用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;
}