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

  • 9
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
【资源说明】 Java大作业基于JavaSwing实现的模拟程序员计算器源码+目说明.zip 课题要求: 基本要求: `已完成`按照TI 程序员计算器(1982 年LCD版本)的原始面板键盘和显示布局设计出计算器的交互窗口. `已完成`实现 10 进制和 16 进制的基础算术运算。即不含括号的单步加减乘除运算。 提高要求: `已完成`实现输入的 10 进制数和 16 进制数之间的相互转换 `已完成`实现与、或、异或、 `已完成`反码、补码和移位运算 `已完成`实现单一进制模式下的带括号的组合多步运算 `已完成`实现混合进制模式下带括号的组合多步运算 `已完成`设计运算溢出等出错提示。 备注 课题要求中给出的基本要求和提高要求将作为评分依据,根据大作 业评分标准进行评分,在基本要求和提高要求以外实现的其它功能不作为评分依据。 本大作业课题中设计实现的计算器不需要进行以八进制以及二进制输入输出的数据转 换或计算。 【备注】 1.目代码均经过功能验证ok,确保稳定可靠运行。欢迎下载体验! 2.主要针对各个计算机相关专业,包括计算机科学、信息安全、数据科学与大数据技术、人工智能、通信、物联网等领域的在校学生、专业教师、企业员工。 3.目具有丰富的拓展空间,不仅可作为入门进阶,也可直接作为毕设、课程设计、大作业、初期目立演示等用途。 4.当然也鼓励大家基于此进行二次开发。在使用过程中,如有问题或建议,请及时沟通。 5.期待你能在目中找到乐趣和灵感,也欢迎你的分享和反馈!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

药丸01

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

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

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

打赏作者

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

抵扣说明:

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

余额充值