Sha256: 9a9754f59c14f491fd417d40ea1f96ff450a4b6584a90a8894041930b1889c73

Contents?: true

Size: 826 Bytes

Versions: 13

Compression:

Stored size: 826 Bytes

Contents

#ifndef BIGINTEGERALGORITHMS_H
#define BIGINTEGERALGORITHMS_H

#include "BigInteger.hh"

/* Some mathematical algorithms for big integers.
 * This code is new and, as such, experimental. */

// Returns the greatest common divisor of a and b.
BigUnsigned gcd(BigUnsigned a, BigUnsigned b);

/* Extended Euclidean algorithm.
 * Given m and n, finds gcd g and numbers r, s such that r*m + s*n == g. */
void extendedEuclidean(BigInteger m, BigInteger n,
		BigInteger &g, BigInteger &r, BigInteger &s);

/* Returns the multiplicative inverse of x modulo n, or throws an exception if
 * they have a common factor. */
BigUnsigned modinv(const BigInteger &x, const BigUnsigned &n);

// Returns (base ^ exponent) % modulus.
BigUnsigned modexp(const BigInteger &base, const BigUnsigned &exponent,
		const BigUnsigned &modulus);

#endif

Version data entries

13 entries across 13 versions & 4 rubygems

Version Path
rhodes-7.6.0 lib/commonAPI/barcode/ext/platform/qt/src/qzxing/zxing/bigint/BigIntegerAlgorithms.hh
rhodes-7.5.1 lib/commonAPI/barcode/ext/platform/qt/src/qzxing/zxing/bigint/BigIntegerAlgorithms.hh
rhodes-7.4.1 lib/commonAPI/barcode/ext/platform/qt/src/qzxing/zxing/bigint/BigIntegerAlgorithms.hh
zxing_cpp_mac_big_sur-0.1.1 ext/zxing/zxing-cpp/core/src/bigint/BigIntegerAlgorithms.hh
rhodes-7.1.17 lib/commonAPI/barcode/ext/platform/qt/src/qzxing/zxing/bigint/BigIntegerAlgorithms.hh
zxing_cpp_no_cmake-0.1.2 ext/zxing/zxing-cpp/core/src/bigint/BigIntegerAlgorithms.hh
zxing_cpp_no_cmake-0.1.1 ext/zxing/zxing-cpp/core/src/bigint/BigIntegerAlgorithms.hh
rhodes-6.2.0 lib/commonAPI/barcode/ext/platform/qt/src/qzxing/zxing/bigint/BigIntegerAlgorithms.hh
rhodes-6.0.11 lib/commonAPI/barcode/ext/platform/qt/src/qzxing/zxing/bigint/BigIntegerAlgorithms.hh
rhodes-5.5.18 lib/commonAPI/barcode/ext/platform/qt/src/qzxing/zxing/bigint/BigIntegerAlgorithms.hh
rhodes-5.5.17 lib/commonAPI/barcode/ext/platform/qt/src/qzxing/zxing/bigint/BigIntegerAlgorithms.hh
zxing_cpp-0.1.1 ext/zxing/zxing-cpp/core/src/bigint/BigIntegerAlgorithms.hh
zxing_cpp-0.1.0 ext/zxing/zxing-cpp/core/src/bigint/BigIntegerAlgorithms.hh