3
0
Fork 0
mirror of https://github.com/Z3Prover/z3 synced 2025-05-11 09:44:43 +00:00
z3/src/util/ext_gcd.h
Nikolaj Bjorner 4bc044c982 update header guards to be C++ style. Fixes issue #9
Signed-off-by: Nikolaj Bjorner <nbjorner@microsoft.com>
2015-07-08 23:18:40 -07:00

52 lines
932 B
C++

/*++
Copyright (c) 2006 Microsoft Corporation
Module Name:
ext_gcd.h
Abstract:
<abstract>
Author:
Leonardo de Moura (leonardo) 2007-06-09.
Revision History:
--*/
#ifndef EXT_GCD_H_
#define EXT_GCD_H_
template<typename numeral>
void extended_gcd(const numeral & in_a, const numeral & in_b, numeral & gcd, numeral & x, numeral & y) {
numeral a = in_a;
numeral b = in_b;
x = numeral(0);
y = numeral(1);
numeral lastx(1);
numeral lasty(0);
numeral tmp;
numeral quotient;
while (!b.is_zero()) {
tmp = b;
quotient = div(a, b);
b = mod(a, b);
a = tmp;
tmp = x;
x = lastx - (quotient * x);
lastx = tmp;
tmp = y;
y = lasty - (quotient * y);
lasty = tmp;
}
gcd = a;
x = lastx;
y = lasty;
}
#endif /* EXT_GCD_H_ */