大整数相乘算法

当数据的大小超过java基本数据类型所表示的时候,那么我们就需要使用一些手段来解决问题了,当然你也可以使用java的自带的类BigDecimal等,不过这里使用的是一个原始的算法


package com.jintao.algorithm;

import java.util.Arrays;
import java.util.Scanner;

public class BigIntegerMultiply
{

	public static void main(String[] args)
	{
		System.out.println("-------------------大整数相乘算法-------------------");
		Scanner sc = new Scanner(System.in);
		//从控制台输入两个大整数
		System.out.print("输入第一个:");
		String var1 = sc.nextLine();
		System.out.print("输入第二个:");
		String var2 = sc.nextLine();
		sc.close();//关闭输入流
		
		//将两个大整数转换成int[]数组存储
		int a[] = convertStringToInt(var1);
		int b[] = convertStringToInt(var2);
		System.out.println("数a:"+Arrays.toString(a));
		System.out.println("数b:"+Arrays.toString(b));
		//调用大整数乘法方法
		bigIntegerMultiply(a, b);
	}
	
	
	public static void bigIntegerMultiply(int a[],int b[])
	{
		//一般两个整数乘积结果的位数为,m+n或者m+n-1,这里设为最大,
		//最后输出时再判断几位
		int aLength = a.length;//数a长度
		int bLength = b.length;//数b长度
		int midResult[] = new int[aLength+bLength];//中间结果
		
		for(int i = a.length-1; i >=0; i--)
		{
			for(int j = b.length-1; j >= 0; j--)
			{
				midResult[i+j+1] += a[i]*b[j];//逆序存在中间结果中
			}
		}
		
		//处理进位
		for(int i = midResult.length-1; i >0; i--)
		{
			midResult[i-1] += midResult[i]/10;
			midResult[i] = midResult[i]%10;
		}
		
		//处理输出,判断中间结果第一位是否为
		//如果是表示乘积结果只有m+n-1位,从下标1往后输出
		//如果不等于0表示有m+n位全部输出
		output(a);
		System.out.print("*");
		output(b);
		System.out.print("=");
		for(int i = (midResult[0]==0?1:0); i < midResult.length; i++)
		{
			System.out.print(midResult[i]);
		}
	}
	
	public static int[] convertStringToInt(String str)
	{
		int ints[] = new int[str.length()];//长度和string类型一样
		
		for(int i = 0; i < str.length(); i++)
		{
			ints[i] = str.charAt(i) - '0';
		}
		
		return ints;
	}
	
	public static void  output(int a[])
	{
		for(int i:a)
		{
			System.out.print(i);
		}
	}
}

结果:输入第一个:1561654468
输入第二个:51354416
数a:[1, 5, 6, 1, 6, 5, 4, 4, 6, 8]
数b:[5, 1, 3, 5, 4, 4, 1, 6]
1561654468*51354416=80197853197930688

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值