码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • AcWing算法提高课-5.6.1同余方程


    宣传一下 算法提高课整理

    CSDN个人主页:更好的阅读体验

    Start

    原题链接
    题目描述

    求关于 x x x 的同余方程 a x ≡ 1 ( m o d b ) ax ≡ 1 \pmod b ax≡1(modb) 的最小正整数解。

    输入格式

    输入只有一行,包含两个正整数 a , b a,b a,b,用一个空格隔开。

    输出格式

    输出只有一行,包含一个正整数 x x x,表示最小正整数解。

    输入数据保证一定有解。

    数据范围

    2 ≤ a , b ≤ 2 × 1 0 9 2 \le a,b \le 2 \times 10^9 2≤a,b≤2×109

    输入样例:
    3 10
    
    • 1
    输出样例:
    7
    
    • 1

    思路

    我们对 a x ≡ 1 ( m o d b ) ax ≡ 1 \pmod b ax≡1(modb) 进行变形:

    设 y ∈ R y \in \mathbb{R} y∈R,则:

    a x ≡ 1 ( m o d b ) ⇔ a x − b y = 1 ax \equiv1 \pmod b \Leftrightarrow ax-by=1 ax≡1(modb)⇔ax−by=1

    我们知道,扩展欧几里得算法可以计算形如 a x + b y = gcd ⁡ ( a , b ) ax+by=\gcd(a,b) ax+by=gcd(a,b) 的方程的解。

    所以直接进行转化即可。

    注意: 由于题目要求输出正整数解,所以我们输出 ( x   m o d   p + p )   m o d   p (x \bmod p + p) \bmod p (xmodp+p)modp 即可。

    算法时间复杂度 O ( log ⁡ n ) O(\log n) O(logn)
    AC Code

    C + + \text{C}++ C++

    #include 
    #include 
    #include 
    
    using namespace std;
    
    typedef long long LL;
    
    LL exgcd(LL a, LL b, LL &x, LL &y)
    {
        if (!b)
        {
            x = 1, y = 0;
            return a;
        }
    
        LL d = exgcd(b, a % b, y, x);
        y -= a / b * x;
    
        return d;
    }
    
    int main()
    {
        LL a, b, x, y;
        cin >> a >> b;
        exgcd(a, b, x, y);
        cout << (x % b + b) % b << endl;
        return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30

    228aa7bed3e021faf24cf8560d3e47bb.gif

    最后,如果觉得对您有帮助的话,点个赞再走吧!

  • 相关阅读:
    uboot常见函数
    吴恩达《机器学习》6-1->6-3:分类问题、假设陈述、决策界限
    C盘清理命令
    36.Python实现马尔科夫链
    电脑设备打印机驱动安装失败如何解决
    冲刺十五届蓝桥杯P0005单词分析
    Grab 基于 Apache Hudi 实现近乎实时的数据分析
    详解Spring面试IoC和AOP
    [架构设计] 创建型模型
    HUDI概述
  • 原文地址:https://blog.csdn.net/xingchen_2008/article/details/133542021
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号