我已经为类编写了一个程序,我需要递归地评估 a 和 b 的扩展 euclid 算法,返回最大公约数 G,以及来自 as+bt=gcd(a,b) 的 s 和 t。我相当确定我的函数编写正确,但我在传入和传出函数的值时遇到问题。我有一段时间没有编码了,最近才写了伪代码,所以我有点生疏了。
例如,我写了当 b=0 时,返回 (a, 1, 0),但是当我输入 b 作为 0 时,我得到返回 (0, 0, 0) 并且无法弄清楚为什么会发生这种情况。任何帮助或指导将不胜感激。
#include <iostream>
using namespace std;
int ExtGCD (int a, int b)
{
int g, s, t, g1, s1, t1;
if (b == 0) {
return (a, 1, 0);
}
(g1, s1, t1) = ExtGCD(b, a%b);
g = g1;
s = s1;
t = s1 - ((a/b)*t1);
return (g, s, t);
}
int main(int argc, char* argv[])
{
int a,b, g2, s2, t2, temp;
cout << "Please input a: ";
cin >> a;
cout << "Please input b: ";
cin >> b;
if (b > a) {
temp = a; a = b; b = temp;
}
(g2, s2, t2) = ExtGCD (a, b);
cout << "G = "<< g2 << ", S = " << s2 << ", T = " << t2;
return 0;
}