This is a java program to perform arithmetic operations on numbers which are greater than size of the integers.
Here is the source code of the Java Program to Perform Arithmetic Operations on Numbers of Size Greater than that of Int Without Using any Data Type of Size Greater than Int. The Java program is successfully compiled and run on a Windows system. The program output is also shown below.
/**
* Java Program to Perform Arithmetic Operations on Numbers of Size Greater than that of Int Without Using any Data Type of Size Greater than Int
**/
package com.sanfoundry.numerical;
import java.util.Scanner;
public class BigNumber
{
static final int MAXDIGITS = 100; /* maximum length bignum */
static final int PLUS = 1; /* positive sign bit */
static final int MINUS = -1; /* negative sign bit */
char digits[]; /* represent the number */
int signbit; /* 1 if positive, -1 if negative */
int lastdigit; /* index of high-order digit */
BigNumber()
{
digits = new char[MAXDIGITS];
intToBigNumber(0);
}
void printBigNumber()
{
int i;
if (signbit == MINUS)
System.out.printf("- ");
for (i = lastdigit; i >= 0; i--)
System.out.printf("%c", '0' + digits[i]);
System.out.printf("\n");
}
void intToBigNumber(int s)
{
if (s >= 0)
signbit = PLUS;
else
signbit = MINUS;
for (int i = 0; i < MAXDIGITS; i++)
digits[i] = (char) 0;
lastdigit = -1;
int t = Math.abs(s);
while (t > 0)
{
lastdigit++;
digits[lastdigit] = (char) (t % 10);
t /= 10;
}
if (s == 0)
lastdigit = 0;
}
BigNumber addBigNumber(BigNumber b)
{
int carry, i;
BigNumber c = new BigNumber();
if (signbit == b.signbit)
c.signbit = signbit;
else
{
if (signbit == MINUS)
{
signbit = PLUS;
c = b.subtractBigNumber(this);
signbit = MINUS;
}
else
{
b.signbit = PLUS;
c = this.subtractBigNumber(b);
b.signbit = MINUS;
}
return c;
}
c.lastdigit = Math.max(lastdigit, b.lastdigit) + 1;
carry = 0;
for (i = 0; i <= c.lastdigit; i++)
{
c.digits[i] = (char) ((carry + digits[i] + b.digits[i]) % 10);
carry = (carry + digits[i] + b.digits[i]) / 10;
}
c.zeroJustify();
return c;
}
BigNumber subtractBigNumber(BigNumber b)
{
int borrow, v, i;
BigNumber c = new BigNumber();
if (signbit == MINUS || b.signbit == MINUS)
{
b.signbit = -b.signbit;
c = addBigNumber(b);
b.signbit = -b.signbit;
return c;
}
if (compareBigNumber(b) == PLUS)
{
c = b.subtractBigNumber(this);
c.signbit = MINUS;
return c;
}
c.lastdigit = Math.max(lastdigit, b.lastdigit);
borrow = 0;
for (i = 0; i <= c.lastdigit; i++)
{
v = digits[i] - borrow - b.digits[i];
if (digits[i] > 0)
borrow = 0;
if (v < 0)
{
v = v + 10;
borrow = 1;
}
c.digits[i] = (char) (v % 10);
}
c.zeroJustify();
return c;
}
int compareBigNumber(BigNumber b)
{
int i;
if (signbit == MINUS && b.signbit == PLUS)
return PLUS;
if (signbit == PLUS && b.signbit == MINUS)
return MINUS;
if (b.lastdigit > lastdigit)
return PLUS * signbit;
if (lastdigit > b.lastdigit)
return MINUS * signbit;
for (i = lastdigit; i >= 0; i--)
{
if (digits[i] > b.digits[i])
return MINUS * signbit;
if (b.digits[i] > digits[i])
return PLUS * signbit;
}
return 0;
}
void zeroJustify()
{
while (lastdigit > 0 && digits[lastdigit] == 0)
lastdigit--;
if (lastdigit == 0 && digits[0] == 0)
signbit = PLUS; /* hack to avoid -0 */
}
void digitShift(int d)
{
int i;
if (lastdigit == 0 && digits[0] == 0)
return;
for (i = lastdigit; i >= 0; i--)
digits[i + d] = digits[i];
for (i = 0; i < d; i++)
digits[i] = 0;
lastdigit += d;
}
BigNumber multiplyBigNumber(BigNumber b)
{
BigNumber row = new BigNumber();
BigNumber tmp = new BigNumber();
BigNumber c = new BigNumber();
int i, j;
row.signbit = this.signbit;
row.lastdigit = this.lastdigit;
System.arraycopy(this.digits, 0, row.digits, 0, this.digits.length);
for (i = 0; i <= b.lastdigit; i++)
{
for (j = 1; j <= b.digits[i]; j++)
{
tmp = c.addBigNumber(row);
c = tmp;
}
row.digitShift(1);
}
c.signbit = signbit * b.signbit;
c.zeroJustify();
return c;
}
BigNumber divideBigNumber(BigNumber b)
{
BigNumber row = new BigNumber();
BigNumber tmp = new BigNumber();
BigNumber c = new BigNumber();
int asign, bsign, i;
c.signbit = signbit * b.signbit;
asign = signbit;
bsign = b.signbit;
signbit = PLUS;
b.signbit = PLUS;
c.lastdigit = lastdigit;
for (i = lastdigit; i >= 0; i--)
{
row.digitShift(1);
row.digits[0] = digits[i];
c.digits[i] = 0;
while (row.compareBigNumber(b) != PLUS)
{
c.digits[i]++;
tmp = row.subtractBigNumber(b);
row = tmp;
}
}
c.zeroJustify();
signbit = asign;
b.signbit = bsign;
return c;
}
}
public class ArithmeticOpsBigNumbers
{
public static void main(String[] args)
{
int a, b;
BigNumber n1 = new BigNumber();
BigNumber n2 = new BigNumber();
BigNumber n3 = new BigNumber();
BigNumber zero = new BigNumber();
Scanner sc = new Scanner(System.in);
while (sc.hasNextInt())
{
a = sc.nextInt();
b = sc.nextInt();
System.out.printf("a = %d b = %d\n", a, b);
n1.intToBigNumber(a);
n2.intToBigNumber(b);
n3 = n1.addBigNumber(n2);
System.out.printf("Addition: ");
n3.printBigNumber();
System.out.printf("Comparing Numbers a ? b: %d\n",
n1.compareBigNumber(n2));
n3 = n1.subtractBigNumber(n2);
System.out.printf("Subtraction: ");
n3.printBigNumber();
n3 = n1.multiplyBigNumber(n2);
System.out.printf("Multiplication: ");
n3.printBigNumber();
zero.intToBigNumber(0);
if (zero.compareBigNumber(n2) == 0)
System.out.printf("Division: NaN \n");
else
{
n3 = n1.divideBigNumber(n2);
System.out.printf("Division: ");
n3.printBigNumber();
}
}
sc.close();
}
}
Output:
$ javac ArithmeticOpsBigNumbers.java $ java ArithmeticOpsBigNumbers 12342424 12313423 a = 12342424 b = 12313423 Addition: 24655847 Comparing Numbers a ? b: -1 Subtraction: 29001 Multiplication: 151977487557352 Division: 1
Related posts:
Java Program to Implement RoleUnresolvedList API
Using Java Assertions
Java Program to Implement Hash Tables with Quadratic Probing
Life Cycle of a Thread in Java
How to Manually Authenticate User with Spring Security
Multipart Upload with HttpClient 4
Wrapper Classes in Java
Adding a Newline Character to a String in Java
Easy Ways to Write a Java InputStream to an OutputStream
Spring 5 WebClient
Java Program for Topological Sorting in Graphs
Most commonly used String methods in Java
OAuth2 for a Spring REST API – Handle the Refresh Token in Angular
Java Program to Implement Quick sort
Ép kiểu trong Java (Type casting)
Comparing Two HashMaps in Java
Spring Boot - Cloud Configuration Server
A Guide to Concurrent Queues in Java
New Features in Java 9
Spring Boot Annotations
Cơ chế Upcasting và Downcasting trong java
Java Program to Implement Treap
Queue và PriorityQueue trong Java
Java Program to Implement AA Tree
Receive email by java client
Java Program to Implement Hash Tables with Linear Probing
Java Program to Implement Weight Balanced Tree
Java Program to Implement Booth Algorithm
Java Program to implement Bit Matrix
Spring Boot: Customize Whitelabel Error Page
Java Program to Implement Merge Sort on n Numbers Without tail-recursion
Java Program to Find the Longest Path in a DAG