Java中两个大数之间的相关运算及BigInteger两段实例代码,具体如下。
大数相减
import java.util.Scanner;
public class BigNumber
{
public static void main(String[] args)
{
Scanner scan=new Scanner(System.in);
String a,b;
while (scan.hasNext())
{
BigNumber big=new BigNumber();
a=scan.nextLine();
b=scan.nextLine();
System.out.println(big.bigNumberSub(a,b));
}
}
public String bigNumberSub(String x,String y)
{
//String result=null;
char[] a=x.toCharArray();
char[] b=y.toCharArray();
int lenA=a.length;
int lenB=b.length;
int len=lenA>lenB?lenA:lenB;
int[] result=new int[len];
//字符串反转
char[] A=new char[lenA];
char[] B=new char[lenB];
for (int i=0;ilenB)
{
sign='+';
} else
{
for (int i=lenA-1;i>=0;i--)
{
if (A[i]B[i])
{
sign='+';
break;
}
}
}
//
int aint,bint;
for (int i=0;i=0;i--)
{
if (result[i]==0&&flag)
{
} else
{
sb.append(result[i]);
flag=false;
}
}
return sb.toString();
//return result;
}
}
结果:
在Java中,还可以通过BigInteger类来解决精度问题。
import java.util.Scanner;
import java.math.BigInteger;
public class BigNumber
{
public static void main(String[] args)
{
Scanner scan=new Scanner(System.in);
while (scan.hasNext())
{
BigInteger b1=new BigInteger(scan.nextLine());
BigInteger b2=new BigInteger(scan.nextLine());
System.out.println(b1.add(b2));
//System.out.println(000);
}
}
}
结果
接着再看一则代码示例:
package com.test1;
import java.math.*;
import java.math.BigInteger;
public class test100 {
static BigInteger k=BigInteger.valueOf(1);
static BigInteger j=BigInteger.valueOf(91);
static BigInteger n;
BigDecimal l=new BigDecimal("100");
static BigInteger m=new BigInteger("100");
public static void main(String[] args) {
// TODO Auto-generatedmethod stub
// k=BigInteger.valueOf(1);
// k=new BigInteger("1");
for(int i=1;i<=5;i++){
k=k.multiply(j);
System.out.println(k.toString());
// n=k.remainder(m);
n=k.remainder(m);
System.out.println(n.toString());
}
}
}
结果:
总结
以上就是本文关于Java中两个大数之间的相关运算及BigInteger代码示例的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站:
java算法实现红黑树完整代码示例
java实现的各种排序算法代码示例
Java小程序计算圆周率代码
如有不足之处,欢迎留言指出。



