Java-计算在1+1/2!+1/3!+1/4! … 的在不溢出的情况下,有限项求和

  这是我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语言,除了部分不同,大部分还是很像的,这让我做这个作业时感到轻松。然后,这道题并不难,把问题拆分成小问题,一个一个处理,最后再联系起来,就可以解决。最后,感觉这程序写的并不好,有点冗长,并不精简。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

药丸01

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值