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

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

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);
}
}
温馨提示:答案为网友推荐,仅供参考
第1个回答  2007-11-04
// 这问题用递归函数解决很方便、简洁

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));
  }
}
第2个回答  2007-11-03
写一个简单的你看看是否可以
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当然要你自己改
第3个回答  2007-11-06
回答者:火星微生物 - 魔法师 四级 11-4 15:56
第4个回答  2007-10-26
这都不会啊???