高精度算法【Java】(待更新中~)

高进度加法

在Java中可以使用BigInteger进行高精度计算,除此也可以仿照竖式相加的计算原理进行计算。

BigInteger 提供所有 Java 的基本整数操作符的对应物,并提供 java.lang.Math 的所有相关方法。另外,BigInteger 还提供以下运算:模算术、GCD 计算、质数测试、素数生成、位操作以及一些其他操作.

核心思想:

将两个数转为字符数组,都倒序后,进行对应位相乘,将有进位的值加到下次计算中。

算法实现:

java 复制代码
import java.util.Scanner;

public class GJD_addition {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        char[] a = scanner.next().toCharArray();
        char[] b = scanner.next().toCharArray();
        int la = a.length;
        int lb = b.length;
        int lc = Math.max(la,lb)+1;
        int[] c = new int[lc];

        //将两个数组转置,并将元素转为数字
        int[] s1 = new int[lc];
        int[] s2 = new int[lc];
        for (int i = 0; i < la; i++) {
            s1[la-i-1] = a[i]-'0';
        }
        for (int i = 0; i < lb; i++) {
            s2[lb-i-1] = b[i]-'0';
        }
        //进行加法

        for (int i = 0; i < lc-1; i++) {
            c[i] += s1[i]+s2[i];
            c[i+1] = c[i]/10;
            c[i] = c[i]%10;
        }
        if (c[lc-1]==0){
            lc--;
        }
        for (int i =lc-1; i >=0; i--) {
            System.out.print(c[i]);
        }
    }
}

相关力扣题:

2. 两数相加

LCR 025. 两数相加 II

445. 两数相加 II

67. 二进制求和

高精度减法

高精度乘法

高精度除法

(持续更新中~)

相关推荐
爱读源码的大都督4 分钟前
挑战一下,用Java手写Transformer,先手写QKV,能成功吗?
java·后端·程序员
华仔啊6 分钟前
面试官灵魂拷问:count(1)、count(*)、count(列)到底差在哪?MySQL 性能翻车现场
java·后端
用户0332126663679 分钟前
在Word 中插入页眉页脚:实用 Java 指南
java
奔跑吧邓邓子10 分钟前
【Java实战㊱】Spring Boot邂逅Redis:缓存加速的奇妙之旅
java·spring boot·redis·缓存·实战
杨杨杨大侠12 分钟前
Atlas-Event:高性能事件处理与监控系统
java·github·eventbus
杨杨杨大侠15 分钟前
Atlas Event:解锁事件驱动的潜能
java·github·eventbus
兴科Sinco19 分钟前
[leetcode 1]给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出和为目标值 target 的那两个整数[力扣]
python·算法·leetcode
失散1320 分钟前
分布式专题——4 大厂生产级Redis高并发分布式锁实战
java·redis·分布式·缓存·架构
沐怡旸21 分钟前
【算法--链表】138.随机链表的复制--通俗讲解
算法·面试
MacroZheng22 分钟前
堪称一站式管理平台,同时支持Linux、MySQL、Redis、MongoDB可视化管理!
java·linux·后端