当前位置:首页 > 芯闻号 > 充电吧
[导读]这个应该是我在noip前就应该会的东西 ,但是当时也许只是记下了代码吧 ,现在有诸多的不理解。后来借着书和几篇博客弄懂了并小证了一下,鉴于网上有些博客关于这个的写的真的不好看,所以自己来总结一下,顺带

这个应该是我在noip前就应该会的东西 ,但是当时也许只是记下了代码吧 ,现在有诸多的不理解。后来借着书和几篇博客弄懂了并小证了一下,鉴于网上有些博客关于这个的写的真的不好看,所以自己来总结一下,顺带以后也能看。
顺带一提,表示a,b的最大公约数。

欧几里德算法

辗转相除法求最大公约数问题,同可求最小公倍数。
既然是辗转相除法,自然就是%%%,%到互相整除为止。代码也很详尽简洁。

int regulargcd(int x,int y)
{
    return y==0?x:(regulargcd(y,x%y));
}

最小公倍数为两数之积除以他们的最大公约数,相信大家都能明白。

扩展欧几里德算法

我之前一直困惑的是它为什么可以求不定方程的解,后来基本明白了:
给定一个形如方程,求它的整数解。
我们知道为整数,是整数,使得为整数解,那么需要约掉系数中相同的部分,于是
所以说,假设我们有,则方程的解为的t倍,那么原问题转化为求方程的解了。

再推到一般,若互质,有有解。

然后接下来我们考虑特殊解的情况:

递归的最终结果为,假定方程有解,那么最终有,即,即,出现,这是在求时递归形成的。若我们也这样地求解方程呢?

于是我们来找与的关系,由于(整数除法) 所以代入有

于是原方程解为。
这样我们就能递归地计算方程的解了。

int extgcd(int a,int b,int &x,int &y)
{
    if(b==0)
    {
        x=1;
        y=0;
        return a;
    }
    else
    {
        int ans;
        ans=extgcd(b,a%b,x,y);
        int tmp=x;
        x=y;
        y=tmp-(a/b)*y;
        return ans;
    }
}

不定方程不是有很多解吗?是的,这只是最小解。设最小解为,它的所有解为和。(自己带到方程里展开就有恒等式,这里不证了)当时,有,。

    while(x<=0)
    {
        x+=(b/res);
    }
    printf("%dn",x);

例题:zoj3609求逆元
方法同上,AC代码

#include#include#include#include#include#include#include//zoj3609 AC
using namespace std;

int extgcd(int a,int b,int &x,int &y)
{
    if(b==0)
    {
        x=1;
        y=0;
        return a;
    }
    else
    {
        int ans;
        ans=extgcd(b,a%b,x,y);
        int tmp=x;
        x=y;
        y=tmp-(a/b)*y;
        return ans;
    }
}

int regulargcd(int x,int y)
{
    return y==0?x:(regulargcd(y,x%y));
}

int main()
{
    int a,b;
    int cas;
    scanf("%d",&cas);
    for(int z=0;z0)
            {
                printf("%dn",x);
            }
            else
            {
                while(x<=0)
                {
                    x+=(b/res);
                }
                printf("%dn",x);
            }
        }
        else
        {
            printf("Not Existn");
        }
    }
    return 0;
}

关于逆元,请移步逆元-wiki
谢谢看到这里

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

9月2日消息,不造车的华为或将催生出更大的独角兽公司,随着阿维塔和赛力斯的入局,华为引望愈发显得引人瞩目。

关键字: 阿维塔 塞力斯 华为

加利福尼亚州圣克拉拉县2024年8月30日 /美通社/ -- 数字化转型技术解决方案公司Trianz今天宣布,该公司与Amazon Web Services (AWS)签订了...

关键字: AWS AN BSP 数字化

伦敦2024年8月29日 /美通社/ -- 英国汽车技术公司SODA.Auto推出其旗舰产品SODA V,这是全球首款涵盖汽车工程师从创意到认证的所有需求的工具,可用于创建软件定义汽车。 SODA V工具的开发耗时1.5...

关键字: 汽车 人工智能 智能驱动 BSP

北京2024年8月28日 /美通社/ -- 越来越多用户希望企业业务能7×24不间断运行,同时企业却面临越来越多业务中断的风险,如企业系统复杂性的增加,频繁的功能更新和发布等。如何确保业务连续性,提升韧性,成...

关键字: 亚马逊 解密 控制平面 BSP

8月30日消息,据媒体报道,腾讯和网易近期正在缩减他们对日本游戏市场的投资。

关键字: 腾讯 编码器 CPU

8月28日消息,今天上午,2024中国国际大数据产业博览会开幕式在贵阳举行,华为董事、质量流程IT总裁陶景文发表了演讲。

关键字: 华为 12nm EDA 半导体

8月28日消息,在2024中国国际大数据产业博览会上,华为常务董事、华为云CEO张平安发表演讲称,数字世界的话语权最终是由生态的繁荣决定的。

关键字: 华为 12nm 手机 卫星通信

要点: 有效应对环境变化,经营业绩稳中有升 落实提质增效举措,毛利润率延续升势 战略布局成效显著,战新业务引领增长 以科技创新为引领,提升企业核心竞争力 坚持高质量发展策略,塑强核心竞争优势...

关键字: 通信 BSP 电信运营商 数字经济

北京2024年8月27日 /美通社/ -- 8月21日,由中央广播电视总台与中国电影电视技术学会联合牵头组建的NVI技术创新联盟在BIRTV2024超高清全产业链发展研讨会上宣布正式成立。 活动现场 NVI技术创新联...

关键字: VI 传输协议 音频 BSP

北京2024年8月27日 /美通社/ -- 在8月23日举办的2024年长三角生态绿色一体化发展示范区联合招商会上,软通动力信息技术(集团)股份有限公司(以下简称"软通动力")与长三角投资(上海)有限...

关键字: BSP 信息技术
关闭
关闭