大整数相乘java_大整数乘法—java实现

大整数相乘java_大整数乘法—java实现大整数相乘参考博客:https://blog.csdn.net/oh_maxy/article/details/10903929https://blog.csdn.net/u010867294/article/details/77482306大整数相乘,对于计算机来说,由于整数的范围存在限制,如果数值太大,则两个较大整数及其结果在表示时就将可能产生溢出。因此,对于两个大整数的乘法我们就需要将其转化…

大家好,又见面了,我是你们的朋友全栈君。

大整数相乘

参考博客:

https://blog.csdn.net/oh_maxy/article/details/10903929

https://blog.csdn.net/u010867294/article/details/77482306

大整数相乘,对于计算机来说,由于整数的范围存在限制,如果数值太大,则两个较大整数及其结果在表示时就将可能产生溢出。因此,对于两个大整数的乘法我们就需要将其转化为字符串来进行求解。

分治法实现大整数相乘—算法思想:

当我们输入两个大整数num1,num2,长度分别为n,m,计算机无法直接计算其结果,采用分而治之的思想,我们可以分别将两个数均分为四个部分,记作A,B,C,D,其中:

A为num1的前n/2,

B为num1的后n/2,

C为num2的前m/2

D为num2的后m/2

至此,我们有:

num1 * num2 = (A * 10^(n/2) + B) * (C * 10^(m/2) + D)= AC * 10实现代码:

import java.util.*;

import static java.util.Collections.reverse;

/**

* @author

* @date 2020/10/1 – 20:55

*/

public class DivideMultiply {

public static void main(String[] args) {

int aLen, bLen;

Scanner scanner = new Scanner(System.in);

System.out.println(“请输入一个长整数x:”);

String as = scanner.nextLine();

System.out.println(“请输入另一个长整数y:”);

String bs = scanner.nextLine();

aLen = as.length();

bLen = bs.length();

List an = new ArrayList<>();

List bn = new ArrayList<>();

List cn;

//数字存入集合

for (int i = 0; i < aLen; i++) {

an.add(as.charAt(i) – ‘0’);

}

for (int i = 0; i < bLen; i++) {

bn.add(bs.charAt(i) – ‘0’);

}

cn = divideMultiply(an, bn, 0, 0);

//求得结果显示

for (Integer i : cn) {

System.out.print(i);

}

}

//求大整数相乘

public static List divideMultiply(List an, List bn, int x, int y) {

int al = an.size();

int bl = bn.size();

int ax = x;

int by = y;

if (al == 1) { //当递归到存在数据长度为1的值时进行乘法运算,结束递归

return multiply(bn, an, x, y);

}

if (bl == 1) {

return multiply(an, bn, x, y);

}

x = x + al – al / 2;

y = y + bl – bl / 2;

List a = getList(an, 0, al / 2); //将大整数分为四个小整数

List b = getList(an, al / 2, al);

List c = getList(bn, 0, bl / 2);

List d = getList(bn, bl / 2, bl);

List ac = divideMultiply(a, c, x, y); //递归求得ac,ad,bc,cd的值

List ad = divideMultiply(a, d, x, by);

d = getList(bn, bl / 2, bl);

List bc = divideMultiply(b, c, ax, y);

b = getList(an, al / 2, al);

List bd = divideMultiply(b, d, ax, by);

return add(ac, ad, bc, bd);

}

//分治后两数相乘

public static List multiply(List an, List bn, int x, int y) {

List result = new ArrayList<>();

int len;

reverse(an);

for (int i = 0; i <= an.size(); i++) { //首先将相乘结果全部置零

result.add(0);

}

for (int i = 0; i < an.size(); i++) {

result.set(i, result.get(i) + an.get(i) * bn.get(0)); //将相乘的值存入返回值

result.set(i + 1, result.get(i + 1) + result.get(i) / 10); //若相乘的值大于10,则进位

result.set(i, result.get(i) % 10); //进位后留余

}

len = result.size(); //如果返回结果后面还剩余0,则将零去掉

while (result.get(len – 1) == 0 && len > 1) {

result.remove(len – 1);

len–;

}

reverse(result); //将所得解逆置即为乘法所得

int l = x + y; //由于两数相乘时可能有10的幂,所以在结果后补0

while (l > 0) {

result.add(0);

l–;

}

return result;

}

//相乘的结果相加

public static List add(List ac, List ad, List bc, List bd) {

Collections.reverse(ac);

Collections.reverse(ad);

Collections.reverse(bc);

Collections.reverse(bd);

List result = new ArrayList<>();

int len = ac.size() + bc.size() + ad.size() + bd.size();

for (int i = 0; i <= len; i++) {

result.add(0);

}

for (int i = 0; i < ac.size(); i++) {

result.set(i, ac.get(i));

}

for (int i = 0; i < ad.size(); i++) {

result.set(i, result.get(i) + ad.get(i));

}

for (int i = 0; i < bc.size(); i++) {

result.set(i, result.get(i) + bc.get(i));

}

for (int i = 0; i < bd.size(); i++) {

result.set(i, result.get(i) + bd.get(i));

}

for (int i = 0; i < len; i++) {

result.set(i + 1, result.get(i + 1) + result.get(i) / 10);

result.set(i, result.get(i) % 10);

}

while (result.get(len) == 0 && len > 1) {

result.remove(len);

len–;

}

Collections.reverse(result);

return result;

}

//获取集合中的某一部分

public static List getList(List list, int x, int y) {

List list1 = new ArrayList<>();

for (int i = x; i < y; i++) {

list1.add(list.get(i));

}

return list1;

}

}

时间复杂度分析:

该问题类似的将两个大的数相乘转化为了四个小的数相乘,由此可以得出公式,其中字符串转化位集合时间复杂度为n,字符串实现乘法时间复杂度为n,字符串相加,时间复杂度为n,得:

T(n) = 4T(n/2)+3n

由Master定理可得:

a=4,b=2,f(n)=3n,n(logb(a))=O(n2)

因为f(n)=3n=O(n^(logb(a)-c)),得c=1,

所以T(n) = O(n(logb(a)))=O(n2),

(m+n)/2 ↩︎

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/137133.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 108是几位数_调查丰富度时为什么要调查种群数量

    108是几位数_调查丰富度时为什么要调查种群数量求给定区间 [X,Y] 中满足下列条件的整数个数:这个数恰好等于 K 个互不相等的 B 的整数次幂之和。例如,设 X=15,Y=20,K=2,B=2,则有且仅有下列三个数满足题意:17=24+2018=24+2120=24+22输入格式第一行包含两个整数 X 和 Y,接下来两行包含整数 K 和 B。输出格式只包含一个整数,表示满足条件的数的个数。数据范围1≤X≤Y≤231−1,1≤K≤20,2≤B≤10输入样例:15 2022输出样例:3#include<bit

    2022年8月10日
    6
  • Java框架总结

    Java框架总结本系列用来记录常用java框架的基本概念、区别及联系,也记录了在使用过程中,遇到的一些问题的解决方法,方便自己查看,也方便大家查阅。欲速则不达,欲达则欲速!一、SSH1、基本概念SSH框架是JAVAEE中三种框架所集成,分别是Struts,Spring,Hibernate框架所组成,是当前比较流行的javaweb开源框架。集成SSH框架的系统从职责上分为(Struts2–…

    2022年7月9日
    18
  • vueweb端响应式布局_vue响应式原理图文详解「建议收藏」

    vueweb端响应式布局_vue响应式原理图文详解「建议收藏」Vue最显著的特性之一便是不太引人注意的响应式系统(reactivitysystem)。模型层(model)只是普通JS对象,修改它则更新视图(view)。这会让状态管理变得非常简单且直观,不过理解它的工作原理以避免一些常见的问题也是很重要的。本文将详细介绍Vue响应式系统的底层细节。追踪变化把一个普通JS对象传给Vue实例的data选项,Vue将遍历此对象所有的属性,并使用Object.def…

    2022年5月30日
    76
  • Java dom4j生成和解析XML

    Java dom4j生成和解析XMLdom4j使用:需先导入dom4j对应的jar,本章用的是dom4j-1.6.1.jar优点:DOM4J使Java开发的灵活性和XML解析代码易于维护dom4j相关操作类Document:表示整个xml文档,是一个树形结构Eelment:表示一个xml的元素,提供方法操作其子元素,它的文本,属性和名称空间Attribute:表示元素的属性Node:表示元素,属性do…

    2022年6月21日
    30
  • 2020/3/28微信小程序笔记

    2020/3/28微信小程序笔记1.左右布局display:flex;flex-direction:row;2.修改switch组件大小style=’zoom:.6’具体数值看个人而定3.仿个性签名关键词:textareatextarea限制字数关键词:maxlength\minlength4.设置渐变色css background: -webkit-linear-gradient(lef…

    2022年8月18日
    11
  • 推荐一个比较好用的画廊展示图片(支持无限轮播)的控件ViewPagerGallery「建议收藏」

    推荐一个比较好用的画廊展示图片(支持无限轮播)的控件ViewPagerGallery「建议收藏」1.在此我们引用支持无限滑动的3D视觉的画廊效果、平面普通广告栏轮播这个例子中有可以运行的效果,大家可以下载下来先看一下,在我开始使用的时候,发现,想要调整pageitem中的间距,比较困难,并没有暴露方法出来。所以就要看一下源代码,发现,在不使用3D效果,即初始化:initBanner(urlList,false),没有什么问题,(这里说的3D效果,就是左右item要比正在显示的ite…

    2022年4月30日
    55

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号