1. c语言如何求一个数的阶乘
n的阶乘就是从1到的累积,所以可以通过一个for循环,从1到n依次求积即可。
参考代码:
#include "stdio.h"
int main() {
int n,i,s=1;
scanf("%d",&n);
for(i=1;i<=n;i++)//for循环求累积
s=s*i;
printf("%d ",s);
return 0;
}
/*
运行结果:(例如求5的阶乘)
5
120
*/
(1)c语言如何计算阶乘和扩展阅读:
return用法:
return返回一个数值的意思就是把return<表达式>后面表达式的值返回给调用他的函数。举个例子:
int sum(int i,int j)
{
return i+j;
printf("这个语句不会被执行,因为该子函数执行到上面的return语句就无条件结束了");
}
main()
{
int a=10,b=11,c;
c=sum(a,b);
printf("%d",c);
}
2. c语言求阶乘的和
这个题目有局限性的,一旦你的N值超过某个数以后,整个Sn的值就会出现溢出现象。这个程序是很好写的,只要写一个求一个数阶乘的函数fun(int
n)然后用个循环就可以解决问题。
3. 怎么用c语言函数计算出1-100的阶乘之和
利用for循环计算1~100的阶乘,将1~100的阶乘累加到sum中就是所求。
#include<stdio.h>
void main()
{
int i;
double t=1,sum=0; //由于100的阶乘int和long int都放不下.所以用double.
for(i=1;i<=100;i++) //从1循环到100.
{
t = t * i; //计算1~100的阶乘.
sum = sum + t; //将1~100的阶乘累加到sum中.
}
printf("%.0f ",sum); //输出sum.
}
利用for循环计算1~100的阶乘,将1~100的阶乘累加到sum中就是所求。
4. 用c语言编写程序计算1~n的阶乘之和....
错误可能有三个,第一你的main前面没有声明,缺少个int,第二个可能的错误就是没有按照题目的要求进行多股输入,你的代码只是输入一次n就结束程序,第三个是最主要的错误,你的for(j=1;j<=i;j++)
里面每次循环一次就把p赋值为1,如果输入3的话,答案是不是10?1*1+1*1*2+1*2*3=10。如果要这样算的话程序如下:
#include<stdio.h>
int main()
{
int i,j,n;
long p;
long Sn=0;
scanf("%d",&n);
for(i=1;i<=n;i++)
{p=1;
for(j=1;j<=i;j++)
{ p=p*j; }
Sn=Sn+p;
}
printf("%ld\n",Sn);
}
5. 用c语言怎么写1到5的阶乘的和
代码如下:
#define _CRT_SECURE_NO_WARNINGS 1
#include"stdio.h"
#include"stdlib.h"
int main()
{
int n = 0;
printf("请输入一个数字: ");
scanf("%d",&n);
int i = 0;
int ret = 1;
int sum = 0;
for (i = 1; i <= n; i++)
{
ret *= i;
sum += ret;
}
printf("%d ",sum);
system("pause");
return 0;
}
(5)c语言如何计算阶乘和扩展阅读
阶乘计算功能关键算法
利用递归方法求5!
用递归方式求出阶乘的值。递归的方式为:
5!=4!*5
4!=3!*4
3!=2!*3
2!=1!*2
1!=1
即要求出5!,先求出4!;要求出4!,先求出3! … 以此类推。
注意:定义一个函数(或方法),用于求阶乘的值。
在主函数(或主方法)中调用该递归函数(或方法),求出5的阶乘,并输出结果。
packageThird;
publicclassone {
publicstaticvoidmain(String args[]){
intn =5;//输入n的值
//n的阶乘的值为:factorial(n);
System.out.println("5的阶乘是:"+ factorial(n));
}
publicstaticintfactorial(intn){//阶乘求解函数
if(n ==0){//判断传进来的n是否为0,若为零返回阶乘为1
return1;
}
returnn*factorial(n-1);//重新调用函数,继续判断n-1是否为零,
}
}
6. C语言怎么求大数的阶乘
C语言利用数组计算超大整数的阶乘代码
#include <stdio.h>
intmain()
{
intn;
inta[9000];//确保保存最终运算结果的数组足够大
intdigit = 1;//位数
inttemp;//阶乘的任一元素与临时结果的某位的乘积结果
inti, j, carry;//carry:进位
printf("please in put n: ");
scanf("%d",&n);
a[0] = 1;//将结果先初始化为1
for( i=2; i<=n; i++ )//开始阶乘,阶乘元素从2开始依次"登场"
{//按最基本的乘法运算思想来考虑,将临时结果的每位与阶乘元素相乘
for( j=1, carry=0; j<=digit; j++ )
{
temp = a[j-1] * i + carry;//相应阶乘中的一项与当前所得临时结果的某位相乘(加上进位)
a[j-1] = temp % 10;//更新临时结果的位上信息
carry = temp / 10;//看是否有进位
}
while(carry)
{//如果有进位
a[++digit-1] = carry % 10;//新加一位,添加信息。位数增1
carry = carry / 10;//看还能不能进位
}
}
printf("n ! = ");//显示结果
for(j = digit; j >=1;j--)
{
printf("%d",a[j-1]);
}
printf(" ");
return0;
}
#include<stdio.h>
intmain()
{
intn;
inta[9000];//确保保存最终运算结果的数组足够大
intdigit=1;//位数
inttemp;//阶乘的任一元素与临时结果的某位的乘积结果
inti,j,carry;//carry:进位
printf("pleaseinputn: ");
scanf("%d",&n);
a[0]=1;//将结果先初始化为1
for(i=2;i<=n;i++)//开始阶乘,阶乘元素从2开始依次"登场"
{//按最基本的乘法运算思想来考虑,将临时结果的每位与阶乘元素相乘
for(j=1,carry=0;j<=digit;j++)
{
temp=a[j-1]*i+carry;//相应阶乘中的一项与当前所得临时结果的某位相乘(加上进位)
a[j-1]=temp%10;//更新临时结果的位上信息
carry=temp/10;//看是否有进位
}
while(carry)
{//如果有进位
a[++digit-1]=carry%10;//新加一位,添加信息。位数增1
carry=carry/10;//看还能不能进位
}
}
printf("n!=");//显示结果
for(j=digit;j>=1;j--)
{
printf("%d",a[j-1]);
}
printf(" ");
return0;
}
7. 用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);
}
8. C语言中如何编程计算阶乘
常见的有两种:
递归版本:
intFac(intn){
if(n==0)return1;
returnn*Fac(n-1);
}
还有一种是循环版:
intans=1;
for(inti=1;i<=n;i++)ans*=i;
测试方法:
#include<stdio.h>
intFac(intn){
if(n==0)return1;
returnn*Fac(n-1);
}
intmain(){
intn;
while(scanf("%d",&n)!=EOF){
intans=1;
for(inti=1;i<=n;i++)ans*=i;
printf("%d%d ",ans,Fac(n));
}
return0;
}
有个值得注意的地方:阶乘时,数增大的很快,在n达到13时就会超过int的范围,此时可以用long long或是 __int64来存储更高精度的值,如果还想存储更高位的,需要用数组来模拟大数相乘。
9. C语言求1~n阶乘的和
你那个do
while是要做什么呢?输入n为负数则循环输入???还是????
#include
<stdio.h>
long
Fact(int
n);///////////////////////////////////////////////////////函数定义在调用之前,要预先声明
void
main
()
{
int
n,d;
long
b,c;
do
{
printf("请输入一个正整数:");
scanf("%d",&n);
c=0;/////////////////////////////////////////////////////c=0放这边
for
(d=1;d<=n;d++)
{
b=Fact(d);////////////////////////////////////////Fact(n);改成Fact(d);
c=c+b;
}
printf("和为%ld\n",c);
}while
(n<=0);
}
long
Fact(int
n)
{
int
i;
long
result=1;
for
(i=1;i<=n;i++)
result
*=i;
return
result;
}
10. 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);//输出结果。
}