codeforces 710D Two Arithmetic Progressions(线性同余方程)
题目链接:
http://codeforces.com/problemset/problem/710/D
分析:给你两个方程 a1k + b1 and a2l + b2,求在一个闭区间【L,R】中有多少个X,X满足 x = a1k' + b1 = a2l' + b2。
由此可以发现这两个方程满足线性同余,即 x ≡b1mod(a1) 且 x≡b2mod(a2); 也就是 a1k' + b1 = a2l' + b2a.
所以 a1k1 + (-a2k2) = (b2 - b1),由同余方程得 : X ≡ (b2 - b1) mod(a2).
所以我们可以先求的一个特解x0,然后找到它的最小整数解 x,再把x 放在【L,R】里找出它包含多少个。
对于解线性同余方程:
求特殊解
附:取模运算
int mod(int a,int b)
{
if(a >= 0)
return a % b;
else
return a % b + b;
}
线性同余方程
对于方程 a*x+b*y=n;有整数解得充分必要条件是(n %(a,b)==0),这个定理这里就不证明了,数论书上都有。
所以方程 a*x+b*y=n;我们可以先用扩展欧几里德算法求出一组x0,y0。也就是a*x0+b*y0=(a,b);然后两边同时除以(a,b),再乘以n。这样就得到了方程a*x0*n/(a,b)+b*y0*n/(a,b)=n;我们也就找到了方程的一个解。
还有一个定理:若(a,b)=1,且x0,y0为a*x+b*y=n的一组解,则该方程的任一解可表示为:x=x0+b*t,y=y0-a*t;且对任一整数t,皆成立。(这个证明比较简单,就不写了)
这样我们就可以求出方程的所有解了,但实际问题中,我们往往被要求去求最小整数解,所以我们就可以将一个特解x,t=b/(a,b),x=(x%t+t)%t;就可以了。
/*************************************************************************
> File Name: cf710D.cpp
> Author:
> Mail:
> Created Time: 2016年08月27日 星期六 22时28分30秒
************************************************************************/ #include<iostream>
#include<bits/stdc++.h>
using namespace std;
typedef long long ll; ll exgcd(ll a, ll b, ll& x, ll& y)
{
ll d = a;
if(b!=)
{
d = exgcd(b,a % b,y,x);
y -= (a / b) * x;
}
else
{
x = ;
y = ;
}
return d;
} int main()
{
ll a1,b1,a2,b2,L,R;
cin >> a1 >> b1 >> a2 >> b2 >> L >> R;
ll x,y;
ll d = exgcd(a1,a2,x,y);
if((b2 - b1) % d != )
{
cout << << endl;
return ;
}
x *=(b2 - b1)/d;
ll t = a2/d;
x = (x % t + t) %t;
ll cnt = a1 * x + b1;
ll lcm = a1/d *a2;
ll ans = ;
L = max(L,max(b1,b2));
if(L > R)
{
cout << << endl;
return ;
}
if(cnt <= R) ans += (R-cnt)/lcm +;//放在区间里找包含多少个解,需要注意方式
if(cnt < L) ans -= (L-cnt- )/lcm +;
cout << ans << endl;
return ;
}
最新文章
- sql 定义自增id插入数据
- 微信支付开发-Senparc.Weixin.MP详解
- 开源 VS 商业,消息中间件你不知道的那些事
- zoj 2686 Cycle Game 博弈论
- POJ-3669 Meteor Shower(bfs)
- vs2005_the breakpoint will not currently be hit. The source code is different from the original verison.
- 折腾ghost。。。
- springMVC工作原理图
- Ubuntu14.04+CUDA6.5环境下神经网络工具包Deepnet配置
- BZOJ 1492 货币兑换
- Qt实现嵌入桌面的半透明窗口 good
- C语言 extern学习1
- 【总结】关于YUV-RGB格式转换的一些个人理解
- [BJOI2006]狼抓兔子
- LeetCode(46)-Remove Nth Node From End of List
- c#语言中的Process进程类型的使用示例
- vue-cli按需加载,懒加载组件
- 字体图标库 IcoMoon IconFont Font Awesome的使用
- Matlab 2017b遇到绘图低级错误
- 微信小程序 table 简单测试
热门文章
- 紫书 习题 11-15 UVa 1668 (图论构造法)
- 【codeforces 370C】Mittens
- Google C++ Style Guide的哲学
- 锐捷SNMp注意:
- Apache activemq入门示例(maven项目)
- 嵌入式表单字段中的内容可能被server更改以删除不安全的内容。是否要又一次载入您的页面以查看保存结果?
- numeric and int in sql server
- [Project Euler 409] Nim Extreme 解题报告 (统计方案数)
- Linux-php安装mongodb
- Android 自定义的开关按钮——SwitchButton