summaryrefslogtreecommitdiff
path: root/java/math
diff options
context:
space:
mode:
authorTom Tromey <tromey@redhat.com>2003-02-18 18:13:51 +0000
committerTom Tromey <tromey@redhat.com>2003-02-18 18:13:51 +0000
commit6d260b2b5ad4b94d969111899db0343861ff6507 (patch)
treee0c6cde2b4517fe8a5938bfe7c39691874a10012 /java/math
parent26087ec05570ea81ad20150d73837ba2bdcf1c9d (diff)
downloadclasspath-6d260b2b5ad4b94d969111899db0343861ff6507.tar.gz
2003-02-18 Raif S. Naffah <raif@fl.net.au>
* java/math/BigInteger.java (euclidInv): Take result array as an argument. Updated all callers. (modInverse): Removed unused variables.
Diffstat (limited to 'java/math')
-rw-r--r--java/math/BigInteger.java29
1 files changed, 13 insertions, 16 deletions
diff --git a/java/math/BigInteger.java b/java/math/BigInteger.java
index 6a17cf3b7..6f919f785 100644
--- a/java/math/BigInteger.java
+++ b/java/math/BigInteger.java
@@ -1017,8 +1017,8 @@ public class BigInteger extends Number implements Comparable
return xy;
}
- private static final BigInteger[] euclidInv(BigInteger a, BigInteger b,
- BigInteger prevDiv)
+ private static final void euclidInv(BigInteger a, BigInteger b,
+ BigInteger prevDiv, BigInteger[] xy)
{
if (b.isZero())
throw new ArithmeticException("not invertible");
@@ -1027,20 +1027,19 @@ public class BigInteger extends Number implements Comparable
{
// Success: values are indeed invertible!
// Bottom of the recursion reached; start unwinding.
- return new BigInteger[] { neg(prevDiv), ONE };
+ xy[0] = neg(prevDiv);
+ xy[1] = ONE;
+ return;
}
- BigInteger[] result;
// Recursion happens in the following conditional!
// If a just contains an int, then use integer math for the rest.
if (a.words == null)
{
int[] xyInt = euclidInv(b.ival, a.ival % b.ival, a.ival / b.ival);
- result = new BigInteger[] { // non-shared BI
- new BigInteger(xyInt[0]),
- new BigInteger(xyInt[1])
- };
+ xy[0] = new BigInteger(xyInt[0]);
+ xy[1] = new BigInteger(xyInt[1]);
}
else
{
@@ -1050,13 +1049,12 @@ public class BigInteger extends Number implements Comparable
// quot and rem may not be in canonical form. ensure
rem.canonicalize();
quot.canonicalize();
- result = euclidInv(b, rem, quot);
+ euclidInv(b, rem, quot, xy);
}
- BigInteger t = result[0];
- result[0] = add(result[1], times(t, prevDiv), -1);
- result[1] = t;
- return result;
+ BigInteger t = xy[0];
+ xy[0] = add(xy[1], times(t, prevDiv), -1);
+ xy[1] = t;
}
public BigInteger modInverse(BigInteger y)
@@ -1124,9 +1122,8 @@ public class BigInteger extends Number implements Comparable
// quot and rem may not be in canonical form. ensure
rem.canonicalize();
quot.canonicalize();
- BigInteger xy0 = new BigInteger();
- BigInteger xy1 = new BigInteger();
- BigInteger[] xy = euclidInv(y, rem, quot);
+ BigInteger[] xy = new BigInteger[2];
+ euclidInv(y, rem, quot, xy);
result = swapped ? xy[0] : xy[1];
// Result can't be negative, so make it positive by adding the