大数相乘

作者: hipeer | 来源:发表于2018-09-24 20:46 被阅读0次

所谓大数相乘(Multiplication algorithm),就是指数字比较大,相乘的结果超出了基本类型的表示范围,所以这样的数不能够直接做乘法运算。


import java.util.Arrays;
import java.util.Stack;
/**
 * 大数相乘
 */
public class BigNumberMutiply {

    // 反转字符串
    private String reverse(String s) {
        Stack stack = new Stack();
        StringBuffer buffer = new StringBuffer();
        for (int i = 0; i < s.length(); i++) {
            stack.push(s.charAt(i));
        }
        while (!stack.isEmpty()) {
            buffer.append(String.valueOf(stack.pop()));
        }

        return buffer.toString();
    }

    // 计算乘积
    private void mutiply(String factor1, String factor2) {

        factor1 = reverse(factor1);
        factor2 = reverse(factor2);
        int len1 = factor1.length();
        int len2 = factor2.length();

        // 保存结果的数组长度
        int size = len1 + len2 + 3;
        int[] res = new int[size];
        // 结果
        String result = "";

        // 逐位相乘
        for (int i = 0; i < len1; i++) {
            for (int j = 0; j < len2; j++) {
                res[i + j] += (Integer.parseInt(String.valueOf(factor1.charAt(i))))
                        * (Integer.parseInt(String.valueOf(factor2.charAt(j))));
            }
        }

        // 进位处理
        int m = 0;
        while (m < size) {
            int tmp = res[m] / 10;
            res[m] = res[m] % 10;
            if (tmp > 0) {
                res[m + 1] += tmp;
            }
            m++;
        }

        // 找到最高位
        m = size - 1;
        while (res[m] <= 0) {
            m--;
        }

        // 打印结果
        while (m >= 0) {
            result += res[m];
            m--;
        }
        System.out.println("结果:" + result);
    }

    public static void main(String[] args) {
        BigNumberMutiply mutiply = new BigNumberMutiply();
        String factor1 = "12723169871651635965371";
        String factor2 = "9867354656235626523526235665373";

        System.out.println("乘数:" + factor1 + "\n" + "乘数:" + factor2);
        mutiply.mutiply(factor1, factor2);

    }
}


相关文章

  • 大数相乘--golang简单实现

    大数乘法之golang实现所谓大数相乘(Multiplication algorithm),就是指数字比较大,相乘...

  • 大数相乘

    所谓大数相乘(Multiplication algorithm),就是指数字比较大,相乘的结果超出了基本类型的表示...

  • 大数相乘

  • 大数相乘

    两个大数相乘,这两个大数分别是a和b,现在分割成两部分,每一部分都是N位,假设是10进制的,其实对于2进制也同样适...

  • 大数相乘

  • 大数相乘

    别忘了把字符串反转便于求导,还有去除前面的0的时候别忘了结果本来就为0的情况,两个数相乘最长长度为len1+len2。

  • 大数相乘

    给定两个以字符串形式表示的非负整数 num1 和 num2,返回 num1 和 num2 的乘积,它们的乘积也表示...

  • 小算法集锦 : 20行代码实现大数相乘

    1.大数相乘 1.1 js 版本 (不计算注释只需要20行) 1.2 C语言 大数相乘 无依赖 简单的 js 转...

  • 大数相乘算法

    1、计算两个大数相乘的结果。2、算法流程:(1)大数可能超出任何一种整数类型,会引发溢出问题,所以用字符串的格式存...

  • 大数相乘-算法

    参考文章 题目 思路 例如:计算98×21,步骤如下 Objective-C 版 swift 版 待更新

网友评论

    本文标题:大数相乘

    本文链接:https://www.haomeiwen.com/subject/twyhoftx.html