一种不断迭代,求新的求余方程的方法运用中国剩余定理。

总的来说,假设对方程操作。和这个定理的数学思想运用的不多的话。是非常困难的。

參照了这个博客的程序写的: http://scturtle.is-programmer.com/posts/19363.html

这个博客举例说的挺好的:http://blog.csdn.net/mishifangxiangdefeng/article/details/7109217

hdu 3579 Hello Kiki 中国剩余定理(不互质的情况)

对互质的情况,处理起来比較方便,能够直接套模板

本题给出不互质的模线性方程组,求出满足方程的最小正整数解

方案:对于不互质的模线性方程组,能够进行方程组合并。求出合并后的方程的解。这样就能够非常快地推出方程的终于解。

两个方程合并的一种方法:

x = c1 (mod b1)

x = c2(mod b2) 

此时b1,b2不必互质的。

显然能够得到x = k1 * b1 + c1   x = k2* b2 + c2。

两个方程合并一下就能够得到:k1 * b1 = c2 - c1 (mod b2),

这样能够设g=gcd(b1,b2),于是就有b1/g*k1-b2/g*k2=(c2-c1)/g,

显然推断(c2-c1)/g是否为整数就能推断是否存在解。

这样在经过类似的变换就能得到k1 = K (mod (b2/g)),

最后得到x = K*b1 + c1 (mod (b1 * b2/g))。

对于题目所给正整数的要求,仅仅有一种反例,就是结果输出为0的情况,

这个能够特殊考虑。仅仅须要考虑全部数的最小公倍数就可以。

各个式子各个变量的含义都须要理解才干写好这个程序;最后0MS过。这个程序竟然上榜了。

  1. __int64 s, t, g;
  2.  
  3. void extGCD(__int64 a, __int64 b)
  4. {
  5. if (b == 0)
  6. {
  7. s = 1, t = 0, g = a;
  8. }
  9. else
  10. {
  11. extGCD(b, a % b);
  12. __int64 tmp = s;
  13. s = t;
  14. t = tmp - a / b * t;
  15. }
  16. }
  17.  
  18. int main()
  19. {
  20. __int64 m1, m2, r1, r2, m10, m20, c;
  21. int n;
  22.  
  23. while (scanf("%d", &n) != EOF)
  24. {
  25. bool flag = false;
  26. scanf("%lld %lld", &m1, &r1);
  27.  
  28. for (int i = 1; i < n; i++)
  29. {
  30. scanf("%lld %lld", &m2, &r2);
  31. if (flag) continue;
  32. extGCD(m1, m2);//由于定理条件是除数互质,所以除以公约数使得其互质
  33. c = r2 - r1;//k1*m1 == (r2 - r1) (mod m2)
  34. if (c % g)
  35. {
  36. flag = true;
  37. continue;
  38. }
  39. m20 = m2 / g;//这个为新的mod除数。和以下新的m1互质
  40. c /= g;
  41. __int64 r0 = (c * s % m20 + m20) % m20;
  42. r1 = r0 * m1 + r1;
  43. m1 = m1 * m20;//得到新式子的系数: m1 * x + r1 == r2 即:x = r1, r2...(mod m1, m2)
  44. }
  45. if (flag) puts("-1");
  46. else printf("%lld\n", r1);
  47. }
  48. return 0;
  49. }

POJ 2891 Strange Way to Express Integers 中国剩余定理解法的更多相关文章

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

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

  2. POJ 2891 Strange Way to Express Integers(中国剩余定理)

    题目链接 虽然我不懂... #include <cstdio> #include <cstring> #include <map> #include <cma ...

  3. poj 2981 Strange Way to Express Integers (中国剩余定理不互质)

    http://poj.org/problem?id=2891 Strange Way to Express Integers Time Limit: 1000MS   Memory Limit: 13 ...

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

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

  5. poj——2891 Strange Way to Express Integers

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

  6. [POJ 2891] Strange Way to Express Integers

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

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

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

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

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

  9. poj 2891 Strange Way to Express Integers【扩展中国剩余定理】

    扩展中国剩余定理板子 #include<iostream> #include<cstdio> using namespace std; const int N=100005; ...

随机推荐

  1. 【NOIP练习赛】开车

    [NOIP练习赛]T2.开车 Description 老司机小 Q 要在一个十字路口指挥车队开车,这个十字路口可 以描述为一个 n*n 的矩阵,其中第 2 行到第 n-1 行都各有一道横向车 道,第 ...

  2. mariadb的安装

    mysql (分支 mariadb)1.安装mariadb -yum -源码编译安装 -下载rpm安装 yum和源码编译安装的区别? 1.路径区别-yum安装的软件是他自定义的,源码安装的软件./co ...

  3. linux命令(001) -- chkconfig

    一.准备知识 在说明chkconfig命令的用途之前,有必要先了解一下Linux系统中/etc/rc[0-6].d目录的用途. 众所周知,在Linux系统定义了7种不同的启动级别,这7种启动级别的含义 ...

  4. Jenkins-SVN + Maven + Docker

    第1步:安装插件 Subversion Plug-inMaven Integration pluginCloudBees Docker Build and Publish pluginDeploy t ...

  5. Spring Cloud (14) 服务网关-过滤器

    Spring Cloud Zuul作为网关所具备的最基本的功能:路由,还具备另外一个核心的功能:过滤器. 过滤器 通过Spring Cloud Zuul实现的路由功能,我们的微服务可以通过统一的API ...

  6. [ HAOI 2010 ] 最长公共子序列

    \(\\\) \(Description\) 求两个长度\(\le5000\)的大写字母串的\(LCS\)长度及个数,定义两\(LCS\)中某一字符在两序列出现位置有一处不同就视为不同. \(\\\) ...

  7. [ NOIP 2008 ] TG

    \(\\\) \(\#A\) \(Word\) 给出一个长为\(N\)的小写字母串,判断出现所有字母中最多出现次数减最少出现次数得到的答案是否是质数. \(N\in [1,100]\) 直接按题意开桶 ...

  8. JS——stye属性

    1.样式少的时候使用 this.parentNode.style.backgroundColor="yellow"; 2.style是对象 console.log(box.styl ...

  9. Java_Web三大框架之Hibernate+jsp+selvect+HQL注册用户

    Hibernate比SQL语句简单多了,代码冗余少,切方便简洁明了.下面用Hibernate+jsp+selvect+HQL来实现注册用户. 第一步:编写用户实体类和Users2.hbm.xml映射. ...

  10. Node.js概述

    Node.js最重要的特性:通过单线程实现异步处理环境 Node.js解决的问题: Node.js修改了客户端连接服务器端的连接方法,不需要为每个客户端连接创建一个新的线程,而是为每个客户端连接触发一 ...