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);
}
}
// 这问题用递归函数解决很方便、简洁
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));
}
}
写一个简单的你看看是否可槐团以
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当然要你自贺明毁己禅备改
回答者:火星微生物 - 魔法师 四级 11-4 15:56
这都不会啊???