1 问题描述

计算两个大整数相乘的结果。

2 解决方案

2.1 蛮力法

package com.liuzhen.chapter5;

import java.math.BigInteger;

public class BigNumber {
/*
* 参数A:进行乘法运算的大整数A,用字符串形式表示
* 参数B:进行乘法运算的另一个大整数B,用字符串形式表示
* 函数功能:以字符串形式返回A*B的结果
*/
public String getMultiBigNumber(String A,String B){
if(A.length() > B.length()){ //当B字符串长度小于A时,在B字符串前补0,使得两个字符串长度一致
char[] temp = new char[A.length()-B.length()];
for(int i = 0;i < A.length() - B.length();i++)
temp[i] = '0';
B = String.valueOf(temp) + B;
}
if(A.length() < B.length()){ //当A字符串长度小于B时,在A字符串前补0,使得两字符串长度一致
char[] temp = new char[B.length()-A.length()];
for(int i = 0;i < B.length() - A.length();i++)
temp[i] = '0';
A = String.valueOf(temp) + A;
} int len = A.length() + B.length(); char[] arrayA = A.toCharArray();
char[] arrayB = B.toCharArray();
for(int i = 0;i < arrayA.length;i++) //检查字符串A中是否有非数字的字符
if(arrayA[i] < '0' || arrayA[i] > '9')
return null;
for(int i = 0;i < arrayB.length;i++) //检查字符串B中是否有非数字的字符
if(arrayB[i] < '0' || arrayB[i] > '9')
return null; char[] result = new char[len]; //用于存放最终乘法运算结果,长度len表示A*B的最长长度
for(int i = 0;i < len;i++) //初始化字符数组result,各个元素均为'0'
result[i] = '0'; int countI = 0; //用于计算当前B中已经和A中每个字符进行完乘法运算的字符个数
for(int i = arrayB.length-1;i >= 0;i--){
int tempB = arrayB[i] - '0';
int countJ = 0; //用于计算当前A中正在进行乘法运算的字符个数
for(int j = arrayA.length - 1;j >= 0;j--,countJ++){
int tempA = arrayA[j] - '0';
int tempRe = (tempB * tempA) % 10; //用于计算当前位置的数
int tempResult = result[(len-1-countJ)-countI] - '0'; //当前位置已包含的结果
tempResult += tempRe;
//count--表示当前A字符串中进行乘法运算的字符位置,countI表示当前B字符串中进行乘法运算的字符位置
//(count--)-countI则表示当前进行乘法运算两个数字结果的最低位的位置
result[(len-1-countJ)-countI] = (char) (tempResult%10 + 48); //当前位置数最终结果 int tempDi = tempB * tempA / 10 + tempResult / 10; //用于计算进位
for(int k = 1;tempDi > 0;k++){ //处理进位操作
//当前下第k个位置包含的结果
int tempResultK = result[(len-1-countJ)-countI-k] - '0';
tempResultK += tempDi;
result[(len-1-countJ)-countI-k] = (char) (tempResultK%10 + 48);
tempDi = tempResultK / 10;
}
}
countI++;
} return getNoneZeroString(result);
} //去掉字符串前面的0
public String getNoneZeroString(char[] result){
int count = 0;
for(int i = 0;i < result.length;i++){
if(result[i] == '0')
count++;
else
break;
}
char[] A = new char[result.length-count];
for(int i = 0;i < result.length-count;i++)
A[i] = result[count+i];
return String.valueOf(A);
} public static void main(String[] args){
long t1 = System.currentTimeMillis();
BigNumber test = new BigNumber();
String A = "123456789123232342432423441345342523452534235443253254";
String B = "987654322234242424332423414324532542354325235345435435";
System.out.println("大整数A*B的结果:"+test.getMultiBigNumber(A, B));
BigInteger bigInteger1 = new BigInteger("123456789123232342432423441345342523452534235443253254");
BigInteger bigInteger2 = new BigInteger("987654322234242424332423414324532542354325235345435435");
bigInteger2 = bigInteger2.multiply(bigInteger1);
System.out.println("验证后A*B的结果:"+bigInteger2);
long t2 = System.currentTimeMillis();
System.out.println("耗时:"+(t2-t1)+" 毫秒");
}
}

运行结果:

大整数A*B的结果:121932631386721831198089710747298668585104317165230580938992491445929653074852215402191571860797295610655490
验证后A*B的结果:121932631386721831198089710747298668585104317165230580938992491445929653074852215402191571860797295610655490
耗时:4 毫秒

Java实现大整数乘法的更多相关文章

  1. 【老鸟学算法】大整数乘法——算法思想及java实现

    算法课有这么一节,专门介绍分治法的,上机实验课就是要代码实现大整数乘法.想当年比较混,没做出来,颇感遗憾,今天就把这债还了吧! 大整数乘法,就是乘法的两个乘数比较大,最后结果超过了整型甚至长整型的最大 ...

  2. [大整数乘法] java代码实现

    上一篇写的“[大整数乘法]分治算法的时间复杂度研究”,这一篇是基于上一篇思想的代码实现,以下是该文章的连接: http://www.cnblogs.com/McQueen1987/p/3348426. ...

  3. POJ 1001 解题报告 高精度大整数乘法模版

    题目是POJ1001 Exponentiation  虽然是小数的幂 最终还是转化为大整数的乘法 这道题要考虑的边界情况比较多 做这道题的时候,我分析了 网上的两个解题报告,发现都有错误,说明OJ对于 ...

  4. poj2389-Bull Math(大整数乘法)

    一,题意: 大整数乘法模板题二,思路: 1,模拟乘法(注意"逢十进一") 2,倒序输出(注意首位0不输出) 三,步骤: 如:555 x 35 = 19425  5 5 5  5 5 ...

  5. OpenJudge 2980 大整数乘法

    链接地址:http://bailian.openjudge.cn/practice/2980/ 题目: 总时间限制: 1000ms 内存限制: 65536kB 描述 求两个不超过200位的非负整数的积 ...

  6. 大整数乘法python3实现

    因为python具有无限精度的int类型,所以用python实现大整数乘法是没意义的,可是思想是一样的.利用的规律是:第一个数的第i位和第二个数大第j位相乘,一定累加到结果的第i+j位上,这里是从0位 ...

  7. 基于Java的大整数运算的实现(加法,减法,乘法)学习笔记

    大整数,顾名思义就是特别大的整数. 一台64位的机器最大能表示的数字是2的64次方减一: 18446744073709551615 java语言中所能表示的整数(int)最小为-2147483648 ...

  8. 算法笔记_034:大整数乘法(Java)

    目录 1 问题描述 2 解决方案 2.1 蛮力法   1 问题描述 计算两个大整数相乘的结果. 2 解决方案 2.1 蛮力法 package com.liuzhen.chapter5; import ...

  9. 用Java的大整数类BigInteger来实现大整数的一些运算

    关于BigInteger的构造函数,一般会用到两个: BigInteger(String val); //将指定字符串转换为十进制表示形式: BigInteger(String val,int rad ...

随机推荐

  1. C# 数据操作系列 - 5. EF Core 入门

    0.前言 上一章简单介绍了一下ORM框架,并手写了一个类似ORM的工具类.这一章将介绍一个在C#世界里大名鼎鼎的ORM框架--Entity Framework的Core版. Entity Framew ...

  2. PC、APP、H5三端测试的区别

    一,针对同一个系统功能的测试,三端所测的业务流程是一样的 二,一般情况下手机端和PC端都对应一套后台服务,比如说笔者公司所开发的互联网金融平台,整个平台做了分布式服务架构,后台服务包括用户服务.交易服 ...

  3. Lr运行错误Error: Socket descriptor not found. Hint: the problem might be

    在controller中,运行时,报如下错误“Error: Socket descriptor not found.  Hint: the problem might be solved applyi ...

  4. How to create a angular2 project process

    步骤1. 设置开发环境 在开始工作之前,我们必须设置好开发环境. 如果你的机器上还没有Node.js®和npm 和VScode(因为我是用VS工具来编辑的), 请先安装它们. 然后全局安装 Angul ...

  5. ES6常见面试题

    1.es5和es6的区别,说一下你所知道的es6 ECMAScript5,即ES5,是ECMAScript的第五次修订,于2009年完成标准化 ECMAScript6,即ES6,是ECMAScript ...

  6. linux常用命令---yum 工具

    yum 工具 yum工具是红帽子才有的软件管理工具,例如suse乌班图等系统,没有yum,apt-get apt-install

  7. matlab第六章数据分析与多项式计算

    MATLAB练习 第六章数据分析与多项式计算 1.max和min 1.分别求矩阵A中各列和各行元素中的最大值.max和min的用法一样 % [例6.1]分别求矩阵中各列和各行元素中的最大值. A=[5 ...

  8. NO.3 MSP432P4_SDK浏览

    网上关于MSP432的参考资料很少,我们要学习的最权威的资源只有TI提供的SDK.这是好处也是坏处,好处是我们学习的是TI一手资源,不再是拾人牙慧:坏处是英语能力要求较高. 闲话少说,我们先来看SDK ...

  9. 初窥 BB-Framework

     

  10. C++ 海量代码 排查内存/GDI泄漏历程

    排查分两大部分: 1.代码静态分析,通过Code Review查找不合规范的代码点: 2.运行目标软件,结合内存监控工具,分析目标软件的代码,定位内存泄漏点. 目前能找到的代码静态分析软件:Cover ...