3
0
Fork 0
mirror of https://github.com/Z3Prover/z3 synced 2025-04-08 10:25:18 +00:00
z3/lib/ext_gcd.h
Leonardo de Moura e9eab22e5c Z3 sources
Signed-off-by: Leonardo de Moura <leonardo@microsoft.com>
2012-10-02 11:35:25 -07:00

53 lines
935 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_ */