海豚实习-实现两个大数相乘

问题描述:定义大数d为一个数组,表示为:d=a[k-1]*10^(k-1)+a[k-2]*10^(k-2)+...+a[1]*10+a[0](k为数组长度),实现一个函数,返回两个大数相乘的结果

/**

d1=a[k-1]*10^(k-1)+a[k-2]*10^(k-2)+...+a[1]*10+a[0]

d2=b[l-1]*10^(l-1)+b[l-2]*10^(l-2)+...+b[1]*10+b[0]

d1*d2 包含k*l项,这只是没有合并的

每一项可以表示为:d*10^x,然后将(x,d)放在map中,很多实现方法都是直接新生成一个 c[k*l]的数组来保存,但是如果数组过大容易造成内存泄漏,像在java 中,常量池是根据JVM设置的,随便搞个c[k*l]很容易溢出。所以还是搞个hashmap比较好。。。

*/

用java实现的代码如下:

public static int[] bigDataMultiply(int[]d1,int []d2)
	{
		//int []d=new int[100];
		Map<Integer, Integer> map=new HashMap<Integer, Integer>();
		for(int i=0;i<d1.length;i++)
			for(int j=0;j<d2.length;j++)
			{
				if(map.containsKey(i+j))
				{
					map.put(i+j, map.get(i+j)+d1[d1.length-i-1]*d2[d2.length-j-1]);
				}
				else {
					map.put(i+j, d1[d1.length-i-1]*d2[d2.length-j-1]);
				}
			}
		//然后遍历整个map,将一些数据分解合并
		//map中的可以是按照从小到达排列的
		for(int i=0;i<d1.length+d2.length;i++)
		{
			if(map.containsKey(i))
			{
				//将d值分解
				int temp=map.get(i);
				map.put(i,temp%10);
				int j=0;
				while((temp/=10)>0)//大数相乘,并不一定相加只有两位数,所以这里要用一个循环
				{
					j++;
					map.put(i+j, map.containsKey(i+j)?(map.get(i+j)+temp%10):temp%10);
				}
			}
		}
		int []d=new int [map.size()];
		for(Integer k:map.keySet())
		{
			d[map.size()-k-1]=map.get(k);
		}
		return d;
	}
时间: 2024-10-13 00:52:35

海豚实习-实现两个大数相乘的相关文章

实现两个大数相乘

牛客网链接-大数相乘 思路: 内心知道这种方法是可以通过的,但是贼鸡儿麻烦. 输入两个字符串.按照笔算乘法的方式,循环计算.考虑到进位的问题. 代码: package top.simuhunluo; import java.util.Scanner; public class Main { static StringBuffer[] results; static boolean z = true; public static void main(String[] args) { Scanner

Go--实现两个大数相乘

----- import ( "bufio" "fmt" "os" "strings" ) func multi(str1, str2 string) (result string) { if len(str1) == 0 && len(str2) == 0 { result = "0" return } var index1 = len(str1) - 1 var index2 = len

1051:A &#215; B problem 大数相乘

给你两个整数,请你计算A × B. 输入 数据的第一行是整数T(1 ≤ T ≤ 20),代表测试数据的组数.接着有T组数据,每组数据只有一行,包括两个非负整数A和B.但A和B非常大,Redraiment能保证这些数用long来保存一定会溢出.但A和B的位数最大不会超过100位. 输出 对应每组测试数据,你都要输出两行:第一行为:"Case #:", # 代表这是第几组测试数据.第二行是一个等式:"A * B = Sum", Sum 代表 A × B 的结果.你要注意

两大数相乘 -- javascript 实现

(function(){ var multiply = function(n1,n2){ var nstr1 = n1.toString(); var nstr2 = n2.toString(); var carry = 0; var ret = ""; var di = 0; var dj = 0; var dig = 0.1; for(var i = nstr1.length - 1 ;i >= 0;i--) { var tmp = ""; var di

大数相乘

1.算法思路 将大数当做字符串进行处理,也就是将大数用十进制字符数组进行表示,然后模拟人们手工进行“竖式计算”的过程得到乘法的结果. 乘积是逐位相乘,也就是a[i] * b[j],结果加入到积C的第i+j位,即 最后处理进位即可 例如:A =17 = 1*10 + 7 = (7,1)最后是十进制的幂表示法,幂次是从低位到高位,以下同. B=25 = 2*10 + 5 = (5, 2); C = A * B = (7 * 5, 1 * 5 + 2 * 7, 1 * 2) = (35, 19, 2)

java版大数相乘

在搞ACM的时候遇到大数相乘的问题,在网上找了一下,看到了一个c++版本的 http://blog.csdn.net/jianzhibeihang/article/details/4948267 用java搞了一个版本 这里说一下思路 将数字已字符串形式接收,转换成int[]整型数组,然后num1[],num2[]依次相乘,结果保存到result[]中 其他注意的在注释中有说明 1 package com.gxf.test; 2 3 import java.util.Scanner; 4 5 p

大数相乘&mdash;&mdash;模拟乘法的运算规则

#define _CRT_SECURE_NO_WARNINGS #include<stdio.h> #include<string.h> int main() { void add(int a[], int length1, int b[], int length2); char str1[255], str2[255]; int num1[255] = { 0 }, num2[255] = { 0 }; int product[255] = { 0 }, temp[255] =

大数相乘、相加、相减、相除

实现大数的加.减.乘.除运算 1 package com.bignumber.test; 2 3 /** 4 * 大数运算(+.-.*./) 5 * @author chen 6 * 7 */ 8 public class BigNumber { 9 10 public static void main(String[] args) { 11 12 String str1 = "123456789";//大数一 13 String str2 = "9876543210&quo

大数相乘算法C++版

#include <iostream> #include <cstring> using namespace std; #define null 0 #define MAXN 51 //大数相乘 char *big_cheng(char line1[], char line2[]) { short s1[MAXN], s2[MAXN], s[MAXN];//s1,s2:两个乘数:s:乘积的结果 int i, j, k, c; int len1, len2, len; len1 =