浅谈一下大数相乘有关思路(图解)与用java代码具体解决方案

本文主要是介绍浅谈一下大数相乘有关思路(图解)与用java代码具体解决方案,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

浅谈一下大数相乘有关思路(图解)与用java代码具体解决方案

    这两天,Java老师让我们用Java语言写一个关于大数(即超出java关键字,如long等表示的范围之外的整数)加减乘运算的小程序,不用Java自带API。

    至于加减运算在这就不说了,一般的Java实验指导书上都有相关代码,关键是考虑进位,退位。下面着重谈一谈大数相乘的有关思路。考虑到文字不太让人有阅读下去的欲望,下面是用windows7自带画图工具画的具体思路以及具体代码。

    为了方便画图及说明,图以两小数1234和3456相乘为例,大数的思路等同。

思路图解

Step 1:

 

 

Step 2:

Step 3:

  

Step 4:

 

    思路清晰了,下面就应该进行具体的代码实现了。

具体代码实现:

做了两个类成员方法函数,分别为①doMul(String,String):String和②doMul(char[],char[]):int[]

①doMul(String,String):String

/*
大整数乘法的转换函数
*/
public static String doMul(String data1,String data2) {int i = 0,j = 0;if(data1.charAt(0) == '-') {data1 = data1.substring(1);//去掉大整数前面的负号i++;}if(data2.charAt(0) == '-') {data2 = data2.substring(1);//去掉大整数前面的负号j++;}char[] char1 = data1.toCharArray();   char[] char2 = data2.toCharArray();int[] result = doMul(char1,char2);String jieguo = "";if(i+j == 1) {jieguo = "-";for(int k = 0; k < char1.length + char2.length-1; k++)  {jieguo += result[k];}}else {for(int k = 0; k<char1.length+char2.length-1; k++)  {jieguo += result[k];}}return jieguo;
}


②doMul(char[],char[]):int[]

/*
高精度乘法函数
*/
public static int[] doMul(char[] char1 , char[] char2) {int[] a = new int[char1.length];int[] b = new int[char2.length];int[] result = new int[char1.length + char2.length-1];int[][] c = new int[char1.length][char2.length];String jieguo = "";//最终结果的字符串形式for(int i = 0; i<char1.length ; i++) {a[i] = Integer.parseInt(char1[i] + "");}for(int i = 0; i<char2.length ; i++) {b[i] = Integer.parseInt(char2[i] + "");}for(int i = 0; i<char1.length ; i++) {for(int j = 0; j<char2.length; j++) {c[i][j] = a[i] * b[j];//将大整数一位一位相乘}}int k = 0;while(k < char1.length+char2.length-1) {for(int i = 0; i<char1.length; i++) {for(int j = 0; j<char2.length; j++) {if(i+j == k) {result[k] += c[i][j];}}}k++;}for(int i = char1.length+char2.length-1-1; i>0 ;i--) {if(result[i] > 9){result[i-1] += result[i] / 10;result[i] = result[i] % 10;}}return result;
}


③compare(String,String):boolean  // 因为①中包含了,所以在此解释一下

/*
字符串比较函数,比较两字符串长度大小
*/
public static boolean compare(String data1 , String data2) {int i = 0;if(data1.length() > data2.length()) {return false;}else {i = data1.compareTo(data2);if(i > 0) {return false;}else {return true;}}
}

备注:

    如果用Java自带类库写函数就很方便了,下面也一并附上自带类库所写程序。

import java.math.BigInteger;public class BigNumberLibrary {/*** @param args*/public static void main(String[] args) {// TODO Auto-generated method stubBigInteger a = new BigInteger("997945672345647898769");BigInteger b = new BigInteger("59164562345721340329");System.out.println("两大数运算结果为:");BigInteger c = a.add(b);BigInteger d = a.subtract(b);BigInteger e = a.multiply(b);BigInteger f = a.divide(b); // 若除数为0,程序会自动抛出异常BigInteger g = a.remainder(b);System.out.println(a + " + " + b + " = " + c);	System.out.println(a + " - " + b + " = " + d);System.out.println(a + " * " + b + " = " + e);System.out.println(a + " / " + b + " = " + f);System.out.println(a + " % " + b + " = " + g);}
}


结束语:

     自己的想法和代码如上,如果您觉得想法赞,或者对上述有不理解的地方,再或者有更好的想法,欢迎留言,大家相互交流提高。

     至于两大数的除法运算,自己将写在下一篇博客上。

 

这篇关于浅谈一下大数相乘有关思路(图解)与用java代码具体解决方案的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/959304

相关文章

Spring Boot中WebSocket常用使用方法详解

《SpringBoot中WebSocket常用使用方法详解》本文从WebSocket的基础概念出发,详细介绍了SpringBoot集成WebSocket的步骤,并重点讲解了常用的使用方法,包括简单消... 目录一、WebSocket基础概念1.1 什么是WebSocket1.2 WebSocket与HTTP

SpringBoot+Docker+Graylog 如何让错误自动报警

《SpringBoot+Docker+Graylog如何让错误自动报警》SpringBoot默认使用SLF4J与Logback,支持多日志级别和配置方式,可输出到控制台、文件及远程服务器,集成ELK... 目录01 Spring Boot 默认日志框架解析02 Spring Boot 日志级别详解03 Sp

java中反射Reflection的4个作用详解

《java中反射Reflection的4个作用详解》反射Reflection是Java等编程语言中的一个重要特性,它允许程序在运行时进行自我检查和对内部成员(如字段、方法、类等)的操作,本文将详细介绍... 目录作用1、在运行时判断任意一个对象所属的类作用2、在运行时构造任意一个类的对象作用3、在运行时判断

java如何解压zip压缩包

《java如何解压zip压缩包》:本文主要介绍java如何解压zip压缩包问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java解压zip压缩包实例代码结果如下总结java解压zip压缩包坐在旁边的小伙伴问我怎么用 java 将服务器上的压缩文件解压出来,

SpringBoot中SM2公钥加密、私钥解密的实现示例详解

《SpringBoot中SM2公钥加密、私钥解密的实现示例详解》本文介绍了如何在SpringBoot项目中实现SM2公钥加密和私钥解密的功能,通过使用Hutool库和BouncyCastle依赖,简化... 目录一、前言1、加密信息(示例)2、加密结果(示例)二、实现代码1、yml文件配置2、创建SM2工具

Spring WebFlux 与 WebClient 使用指南及最佳实践

《SpringWebFlux与WebClient使用指南及最佳实践》WebClient是SpringWebFlux模块提供的非阻塞、响应式HTTP客户端,基于ProjectReactor实现,... 目录Spring WebFlux 与 WebClient 使用指南1. WebClient 概述2. 核心依

Spring Boot @RestControllerAdvice全局异常处理最佳实践

《SpringBoot@RestControllerAdvice全局异常处理最佳实践》本文详解SpringBoot中通过@RestControllerAdvice实现全局异常处理,强调代码复用、统... 目录前言一、为什么要使用全局异常处理?二、核心注解解析1. @RestControllerAdvice2

Spring IoC 容器的使用详解(最新整理)

《SpringIoC容器的使用详解(最新整理)》文章介绍了Spring框架中的应用分层思想与IoC容器原理,通过分层解耦业务逻辑、数据访问等模块,IoC容器利用@Component注解管理Bean... 目录1. 应用分层2. IoC 的介绍3. IoC 容器的使用3.1. bean 的存储3.2. 方法注

Spring事务传播机制最佳实践

《Spring事务传播机制最佳实践》Spring的事务传播机制为我们提供了优雅的解决方案,本文将带您深入理解这一机制,掌握不同场景下的最佳实践,感兴趣的朋友一起看看吧... 目录1. 什么是事务传播行为2. Spring支持的七种事务传播行为2.1 REQUIRED(默认)2.2 SUPPORTS2

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.