如何证明这种欧几里得(最大公约数)算法的正确性?

发布于 2022-09-02 01:51:00 字数 497 浏览 18 评论 0

#include<stdio.h>
unsigned int gcd(unsigned int M, unsigned int N)
{
    int rem;
    if(M < N)/*exchange value to=>M>N*/
    {
        int temp = M;
        M = N;
        N = temp;
    }
    
    while(N > 0)
    {
        rem = M % N;
        M = N;
        N = rem;
    }
    return M;
}
int main()
{
    printf("%d\n", gcd(25, 45));
    return 0;
}

这种算法通过不断的求余数,直到最后结果为0,倒数第二个数就是最大公因数。这个算法很高效,但是自己怎么能证明最后非0的那个余数就一定是正确答案昵,作为数学渣有点困扰。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

污味仙女 2022-09-09 01:51:00

手打公式太繁,改用拍照。

Image

缱倦旧时光 2022-09-09 01:51:00

GreatestCommonDivisor1.png

借张图)两个数都是由最大公约数堆出来的,所以相减、取模最大公约数肯定是不变的。(直观解释)

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文