我刚开始阅读 Knuth 的编程艺术的第 1 卷,然后到了第 4 页上他描述欧几里得算法的部分。他陈述了求两个数的最大公约数的步骤。你可以在这里阅读更多关于它的信息https://en.wikipedia.org/wiki/Euclidean_algorithm
他逐步介绍了一个找到 199 和 544 的 GCD 的示例,他说 17 作为答案。我很快就实现了算法,但得到了答案 1。使用我的计算器,我也得到了答案 1。
我的代码是。
#import <math.h>
#import <stdio.h>
double GreatestComminDivisor(int m, int n) {
double r = fmod(m, n);
if (m < n) {
int temp = n;
n = m;
m = temp;
}
while (r != 0) {
r = fmod(m, n);
if (r == 0) {
return n;
}
m = n;
n = r;
}
return n;
}
int main(int argc, char const *argv[]) {
int m = 199;
int n = 544;
double answer = GreatestComminDivisor(m, n);
printf("GCD of %i and %i is %f \n", m, n, answer);
return 0;
}
我是否在他的示例中遗漏了一些东西,他是否得到了错误的答案。我试图查找本书第三版的勘误表,但没有得到任何结果。只是想确保我不会发疯。