求解一元线性同余方程组:

x=ri(mod ai) i=1,2,...,k

解一元线性同余方程组的一般步骤:
先求出前两个的解,即:
x=r1(mod a1)     1
x=r2(mod a2)     2
1式等价于x=r1+a1*m,2式等价于x=r2+a2*n
联立可得:m*a1-n*a2=r2-r1=c
若方程有解,则必须(a1,a2)|c
设d=(a1,a2),那么如果有解,即可求得
  m*a1-n*a2=d的解,m=m'
则   m*a1-n*a2=c的解,m0=m'*c/d
通解m*=m0+(a2/d)*i
令s=a2/d,则可以求得m的最小解
  m=(m0%s+s)%s
带入x=r1+a1*m,即可求出解x,设为x0

接下来,由
x=r1(mod a1)     1
x=r2(mod a2)     2
得出x=x0=r1(mod a1),x=x0=r2(mod a2)
由定理可得,x=x0(mod [a1,a2])
设a=lcm(a1,a2),即可将1式和2式合并成一项。
接下来的就重复上面步骤即可。

#include <iostream>
#include <stdio.h> using namespace std;
int k;
//求解方程ax+by=gcd(a,b)
long long exgcd(long long a,long long b,long long &x,long long &y){
if(b==){
x=;
y=;
return a;
}
long long g=exgcd(b,a%b,x,y);
long long tmp=x;
x=y;
y=tmp-(a/b)*y;
return g;
}
int main()
{
long long a1,a2,r1,r2,d,c;
long long x,y,x0;
long long s; //s=a2/d;
while(scanf("%d",&k)!=EOF){
bool flag=true;
scanf("%I64d%I64d",&a1,&r1);
for(int i=;i<k;i++){
scanf("%I64d%I64d",&a2,&r2);
if(!flag)
continue;
/*
解x=r1(mod a1)
x=r2(mod a2)
相当于
解不定方程:x*a1+y*a2=r2-r1
先求解方程:x*a1+y*a2=r2-r1=gcd(a1,a2)
得出解x,则方程x*a1+y*a2=r2-r1的解x0=x*(r2-r1)/gcd(a1,a2)=x*c/d
令s=a2/d,那么
x0的最小解为:x0=(x0%s+s)%s
即可得出解x=r1+x0*a1
然后将x赋值给r1,lcm(a1,a2)赋值给a1,继续求解。
*/
c=r2-r1;
d=exgcd(a1,a2,x,y);
if(c%d!=){
flag=false;
continue;
}
x0=x*c/d;
s=a2/d;
x0=(x0%s+s)%s;
r1=r1+x0*a1;
a1=a1*a2/d;
}
if(flag)
printf("%I64d\n",r1);
else
printf("-1\n");
}
return ;
}

POJ 2891 Strange Way to Express Integers (解一元线性方程组)的更多相关文章

  1. poj 2891 Strange Way to Express Integers (非互质的中国剩余定理)

    Strange Way to Express Integers Time Limit: 1000MS   Memory Limit: 131072K Total Submissions: 9472   ...

  2. poj——2891 Strange Way to Express Integers

    Strange Way to Express Integers Time Limit: 1000MS   Memory Limit: 131072K Total Submissions: 16839 ...

  3. [POJ 2891] Strange Way to Express Integers

    Strange Way to Express Integers Time Limit: 1000MS   Memory Limit: 131072K Total Submissions: 10907 ...

  4. POJ 2891 Strange Way to Express Integers(拓展欧几里得)

    Description Elina is reading a book written by Rujia Liu, which introduces a strange way to express ...

  5. POJ 2891 Strange Way to Express Integers | exGcd解同余方程组

    题面就是让你解同余方程组(模数不互质) 题解: 先考虑一下两个方程 x=r1 mod(m1) x=r2 mod (m2) 去掉mod x=r1+m1y1   ......1 x=r2+m2y2   . ...

  6. poj 2891 Strange Way to Express Integers(中国剩余定理)

    http://poj.org/problem?id=2891 题意:求解一个数x使得 x%8 = 7,x%11 = 9; 若x存在,输出最小整数解.否则输出-1: ps: 思路:这不是简单的中国剩余定 ...

  7. POJ 2891 Strange Way to Express Integers 中国剩余定理MOD不互质数字方法

    http://poj.org/problem?id=2891 711323 97935537 475421538 1090116118 2032082 120922929 951016541 1589 ...

  8. POJ 2891 Strange Way to Express Integers 中国剩余定理 数论 exgcd

    http://poj.org/problem?id=2891 题意就是孙子算经里那个定理的基础描述不过换了数字和约束条件的个数…… https://blog.csdn.net/HownoneHe/ar ...

  9. [poj 2891] Strange Way to Express Integers 解题报告(excrt扩展中国剩余定理)

    题目链接:http://poj.org/problem?id=2891 题目大意: 求解同余方程组,不保证模数互质 题解: 扩展中国剩余定理板子题 #include<algorithm> ...

随机推荐

  1. EMVTag系列5《8E 持卡人验证方法(CVM)列表》

    L: var. up to 252 -R(需求):数据必须存在,在读应用数据过程中,终端不检查 按照优先顺序列出卡片应用支持的所有持卡人验证方法 注:一个应用中可以有多个CVM列表,例如一个用于国内交 ...

  2. arcgis中求多点到一条曲线的最短欧几里得距离

    1.使用的工具:Arctoolbox----Analysis Tools----Proximity----Near工具. 2.注意:在求距离之前一定要先设置好坐标系统.

  3. 6.24 AppCan移动开发者大会:议程重大更新,报名即将关闭

    大会倒计时2天,议程重大更新,报名通道即将关闭! 创业6年,由AppCan主办的第一届移动开发者大会将在本周五盛大召开.超过100万开发者线上参与.现场1500人规模.50家移动互联企业深度参与.30 ...

  4. spring使用JdbcDaoSupport中封装的JdbcTemplate进行query

    1.Dept package cn.hxex.springcore.jdbc; public class Dept { private Integer deptNo; private String d ...

  5. iOS学习之UI可视化编程-XIB

    一.Interface Builder可视化编程 1.Interface Builder简介: GUI:图形用户界面(Graphical User Interface,简称GUI,又称图形用户接口)是 ...

  6. Iframe跨域Session丢失的问题

    很久之前做的一个使用插件实现了图片批量上传,是通过IFrame加载上传面板的,使用google的chrome上传成功了就没怎么理了,最近同事测试时(使用的是360安全浏览器)老是出现上传不了图片的问题 ...

  7. [iOS]MVVM-框架介绍

       我于 2011 年在 500px 找到自己的第一份 iOS 开发工作.虽然我已经在大学里做了好几年 iOS 外包开发,但这才是我的一个真正的 iOS 开发工作.我被作为唯一的 iOS 开发者被招 ...

  8. 【译】理解与分析ios应用的崩溃报告

    源网址: http://developer.apple.com/library/ios/#technotes/tn2151/_index.html 当一个应用程序崩溃时,创建一份“崩溃报告”对于理解崩 ...

  9. SVN中的常见错误(长期更新)

    一 svn中的简写含义. A:add,新增 C:conflict,冲突 D:delete,删除 M:modify,本地已经修改 G:modify and merGed,本地文件修改并且和服务器的进行合 ...

  10. ubuntu 屏幕截图

    无意间发现这个组合 Fn+Shift+t,按下之后,鼠标变成一个十字, 选择一个范围,okay,可以截图了