用JAVA编写程序,计算1!+2!+3!+…+n!的和,其中阶乘的写一个方法实现。

2024-12-04 00:21:21
推荐回答(5个)
回答1:

public class Factorial {

//渣虚判下面的这个方誉陆法利用递归的方法求阶乘
public int getFac(int m)
{
if(m==1)
{
return 1;
}
else
{
return m*getFac(m-1);
}
}
public static void main(String args[])
{
Factorial fac=new Factorial();
//System.out.println(fac.getFac(4));
int sum=0;
for(int i=1;i<=10;i++)
{
sum+=fac.getFac(i);
}
System.out.println("1到10的如改阶乘的和是:"+sum);
}
}

回答2:

// 这问题用递归函数解决很方便、简洁

class RecursiveFactorial {
  static long factorial(int n) {
    return n < 2 ? 1 : n * factorial(n - 1); // 递归
  }

  static long sumOfFactorial(int n) {
    return n < 2 ? 1 : factorial(n) + sumOfFactorial(n - 1); // 也是递归
  }

  public static void main(String[] args) {
    System.out.println("1! + 2! + 3! + ... + 20! == " + sumOfFactorial(20));
  }
}

///////////////////////////////////////////////////////////////////////////////////////////////////
// color4you 说的对
// 下面是非递归式的解决

class NonRecursiveFactorial {
  肆磨static long factorial(long n) {
    for (long i = n - 1; i > 0; i--)
      n *= i;
    return Math.max(1, n);              // 结果无论慧颤如何最少是一
  }

  static long sumOfFactorial(long n) {    // n声明为int也可以
   前雹败 long sum = 0;
    while (n > 0)
      sum += factorial(n--);
    return Math.max(1, sum);
  }

  public static void main(String[] args) {
    System.out.println("1! + 2! + 3! + ... + 20! == " + sumOfFactorial(20));
  }
}

回答3:

写一个简单的你看看是否可槐团以
public class test{
public static void main(String args[]){
int i=1;
int j=1;
int sum;
int n;
for(;i<=n&&n>=1;i++){
j=j*i;sum=sum+j;}
System.out.println("1~10的阶乘和为"+sum);
}
}
你的n当然要你自贺明毁己禅备改

回答4:

回答者:火星微生物 - 魔法师 四级 11-4 15:56

回答5:

这都不会啊???