这是我Java作业的一题,感觉不错,分享一波。
分析问题
题意很明显是要先求阶乘,然后倒数,最后再相加。不过要注意数据的范围,还有循环函数的选择。
设计程序
阶乘
我这里用的是函数的递归来实现的,代码如下:
public static int factorial(int n) {
int result;
if (n == 0|n==1)
result = 1;
else
result = n* factorial(n - 1);
return result;
首先n为项数,result为返回的阶乘的结果。
其次用条件选择语句将项数为0和1单独处理,因为递归用的是第n项乘以n-1项,若n为0,则结果为零,若n为1,则结果也为零,故n的最小值为2,且要把条件选择语句放在函数第一条。
最后是递归,在n大于1的时候,使n递减1的趋势不断调用自身函数,直到n递减到2,开始运算阶乘。
倒数
因为阶乘的结果很大,故底数的数据类型我选择long,即
long base=factorial(n);
求和
首先是阶乘的结果很大,则它的倒数很小,故我用double类型定义和。
其次是要确定求和范围,我用Scanner确定范围。
最后是对于循环的选择,我认为要用while语句。
代码如下:
import java.util.Scanner
public class project
{
public static void main(String[]args)
{
Scanner i=new Scanner(System.in);
System.out.println("请问要求多少项阶乘倒数的和");
int count = i.nextInt();
double sum = 0;
while(count>=1)
{
long base = factorial(count);
sum += 1.0 / base;
count--;
}
i.close();
}
}
总代码
import java.util.Scanner;
public class project {
public static int factorial(int n) {
int result;
if (n == 0|n==1)
result = 1;
else
result = num * factorial(n - 1);
return result;
}//计算底数阶乘
public static void main(String[] args) {
Scanner i = new Scanner(System.in);
System.out.println("请问要求多少项阶乘倒数的和");
int count = i.nextInt();//确定总项数
double sum = 0;
while(count>=1)//求和
{
long base = factorial(count);
sum += 1.0 / base;
count--;
}
System.out.println("结果是"+sum);
i.close();
}
}
总结
这是我第一个Java作业,第一的感受是很像c语言,除了部分不同,大部分还是很像的,这让我做这个作业时感到轻松。然后,这道题并不难,把问题拆分成小问题,一个一个处理,最后再联系起来,就可以解决。最后,感觉这程序写的并不好,有点冗长,并不精简。