• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
村雨sup
自己选的路,跪着也要走完 XD
博客园    首页    新随笔    联系   管理    订阅  订阅
数论练习(4)——同余方程(扩gcd)

CODEVS 1200 同余方程 
题目描述 Description 
求关于 x 同余方程 ax ≡ 1 (mod b)的最小正整数解。

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

输出描述 Output Description 
输出只有一行包含一个正整数x0,即最小正整数解,输入数据保证一定有解。 
【数据范围】 
对于 40% 的数据, 2 ≤b≤ 1,000 ; 
对于 60% 的数据, 2 ≤b≤ 50,000,000 
对于 100% 的数据, 2 ≤a, b≤ 2,000,000,000

#include<bits/stdc++.h>
using namespace std;
typedef long long  ll;

const int inf = 0x3f3f3f3f;
const int maxn = 40000 + 20;
const int moder = 1e9 + 7;
const int K = 256;

ll a,b,x,y;
void extendgcd(ll a,ll b,ll &x,ll &y )
{
    if(b == 0)
    {
        x = 1;
        y = 0;
    }
    else
    {
        extendgcd(b,a%b,y,x);
        y = y - (x * (a / b));
    }

    return;
}

int main()
{
    cin >> a >> b;
    extendgcd(a,b,x,y);
    cout << (x%b+b)%b << endl;
    return 0;
}

ax≡1(modb)等价于ax+bk=1(k为常数)

求出 x 的最小整数解,取模取正数。

1.题目保证有解,根据不定方程 ax+by=c 有解的条件: c mod gcd(a,b) = 0,我们可以得出gcd(a, b) = 1 。

2.由于c=1, 所以在扩展欧几里得算法后不需要再乘c/gcd(a,b). 直接设个将x调整到正数。

 

posted on 2018-02-02 15:09  村雨sup  阅读(198)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3