数据结构和java高手请进!在线等1

2025-06-27 11:24:15
推荐回答(4个)
回答1:

这个只能用字符串 处理了。。
我早期进公司的面试题
哈哈
public class VeryBigNumAdd {
public static void main(String[] args) {
String a="1223232";
for(int i=a.length()-1;i>=0;i--)
{
System.out.print(a.charAt(i));
}
VeryBigNumAdd vbn=new VeryBigNumAdd();
String a="123453245535234677576252241234123523453664563634";
String b="123453243455535634535234123523453664563634";
String result=vbn.doAdd(a,b);
System.out.println("result:"+result);
}
/**
*
* @param a 加数字符串1
* @param b 加数字符串2
* @return 结果字符串
* 分析:
* 1、取得两个字符串的长度
* 2、把两个的长度做比较,并得出较长的长度,及较短的长度
* 3、把长度较短的加数字符串,在左面补0,使之与较长的字符串一样长
* 4、从最高位,一个个数的取出来相加,当然首先得转换为整型
* 5、设置进位,如果两个数相加及加上进位大于等于10,并且这不是最左边一个字符相加,相加结果等于
* (取出1+取出2+进位)-10,并把进位设为1;如果没有大于10,就把进位设为0,如些循环,把
* 相加的结果以字符串的形式结合起来,就得到最后的结果
*/
String doAdd(String a,String b)
{
String str="";
int lenA=a.length();
int lenB=b.length();
int maxLen=(lenA>lenB) ? lenA : lenB;
int minLen=(lenA String strTmp="";
for(int i=maxLen-minLen;i>0;i--)
{
strTmp+="0";
}
//把长度调整到相同
if(maxLen==lenA)
{
b=strTmp+b;
}else
a=strTmp+a;
int JW=0;//进位
for(int i=maxLen-1;i>=0;i--)
{
int tempA=Integer.parseInt(String.valueOf(a.charAt(i)));
int tempB=Integer.parseInt(String.valueOf(b.charAt(i)));
int temp;
if(tempA+tempB+JW>=10 && i!=0)
{
temp=tempA+tempB+JW-10;
JW=1;
}
else
{
temp=tempA+tempB+JW;
JW=0;
}
str=String.valueOf(temp)+str;
}
return str;
}
}

回答2:

用varchar2(255)类型。
需要算法的时候 转换证Internet类型~~~~~~~~~~~

回答3:

BigInteger

回答4:

我来整合一下楼上两位的。

字段设计为varchar2,长度按你的情况看;

从数据库拿出来后大概是这样的
给你可以执行的MAIN方法 放到任何类里面一执行你就知道了。
另外其它的计算打印存储可以参考java1.5_API 包java.math.BigInteger .

public static void main(String ars[]){
BigInteger b = new BigInteger ("12345679867878789098765347689");
BigInteger a = new BigInteger ("12345679867878789098765347689");
BigInteger c = b.add(a);
System.out.print(c);
}