BigInteger用在循环

比如要写如下4个函数

1.SUM(n) = 1 + 2 + 3+ … + n-1 + n]

2.SUM1(n) = 1 + (1+2) + (1+ 2+ 3) + … (1 + 2 + 3 + … +n-1+n)

3.FACT(n) = 1*2*3* . . . *(n-1) * n 

4.FACT_SUM(n) = 1 + 1*2 + 1*2*3 + … + 1*2*3* . . . *(n-1) * n

用long连100都过不了,无比无比的长的数字,试一试BigInteger,第一次写在循环里面,有点不习惯

上代码

import java.io.BufferedInputStream;
import java.math.BigInteger;
import java.util.Scanner;

public class test {
    public static BigInteger sum(BigInteger n) {
        return n.multiply(n.add(BigInteger.ONE)).divide(new BigInteger("2"));
    }

    public static BigInteger sum1(BigInteger n) {
        BigInteger sum = BigInteger.ZERO;
        BigInteger sum1 = BigInteger.ZERO;
        n = n.add(BigInteger.ONE);
        for (BigInteger i = BigInteger.ONE; i.compareTo(n) < 0; i = i.add(BigInteger.ONE)) {
            sum = sum.add(i);
            sum1 = sum1.add(sum);
        }
        return sum1;
    }

    public static BigInteger fact(BigInteger n) {
        BigInteger mul = BigInteger.ONE;
        n = n.add(BigInteger.ONE);
        for (BigInteger i = new BigInteger("2"); i.compareTo(n) < 0; i = i.add(BigInteger.ONE)) {
            mul = mul.multiply(i);
        }
        return mul;
    }

    public static BigInteger fact1(BigInteger n) {
        BigInteger sum = BigInteger.ONE, mul = BigInteger.ONE;
        n = n.add(BigInteger.ONE);
        for (BigInteger i = new BigInteger("2"); i.compareTo(n) < 0; i = i.add(BigInteger.ONE)) {
            mul = mul.multiply(i);
            sum = sum.add(mul);
        }
        return sum;
    }

    public static void main(String[] args) {
        Scanner cin = new Scanner(new BufferedInputStream(System.in));
        BigInteger big = new BigInteger(cin.next());
        cin.close();
        System.out.println(sum(big));
        System.out.println(sum1(big));
        System.out.println(fact(big));
        System.out.println(fact1(big));
    }
}


========================================Talk is cheap, show me the code=======================================

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

砖业洋__

你的鼓励是我持续写作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值