题目链接

【VJ传送门】

题目描述

给你\(a_1...a_n\)和\(m_1...m_n\),求一个最小的正整数\(x\),满足\(\forall i\in[1,n] \equiv a_i(mod \ mi)\)。

分析

很显然,中国剩余定理无法解决\(m_i\)之间非互质的问题。
需要用\(exCRT\)。

假设\(x\)是前\(k-1\)个方程推出来的答案,那么第一个方程可以直接得出自己的答案就是\(a_1\)。
设\(M=lcm(m_1,m_2...m_{k-1})\),那么显然得到\(x+i\times M\)为前\(k-1\)个方程的通解。

考虑到第\(k\)个我们的现在要求的方程。
那么答案就是\(x+t\times M\equiv a_k(mod \ m_k)\)
发现这个方程中只有一个未知数\(t\),那么只需要用扩欧来算出最小解就可以了。

代码

  1. #include <cstdio>
  2. #include <cstring>
  3. #define ll long long
  4. #define inf 0x3f3f3f3f
  5. using namespace std;
  6. template <typename T> T power(T x, T y, T mod) { x %= mod; T res = 1; for (; y; y >>= 1) { if (y & 1) res = (res * x) % mod; x = (x * x) % mod; } return res; }
  7. template <typename T> void read(T &x) {
  8. x = 0; T fl = 1; char ch = 0;
  9. for (; ch < '0' || ch > '9'; ch = getchar()) if (ch == '-') fl = -1;
  10. for (; ch >= '0' && ch <= '9'; ch = getchar()) x = (x << 1) + (x << 3) + (ch ^ 48);
  11. x *= fl;
  12. }
  13. template <typename T> void write(T x) {
  14. if (x < 0) x = -x, putchar('-');
  15. if (x > 9) write(x / 10); putchar(x % 10 + '0');
  16. }
  17. template <typename T> void writeln(T x) { write(x); puts(""); }
  18. ll a[10005], m[10005], M = 1ll, ans = inf * 1ll, x, y;
  19. int n;
  20. ll gcd(ll a, ll b) { return b == 0? a: gcd(b, a % b); }
  21. ll exgcd(ll a, ll b, ll &x, ll &y) {
  22. if (!b) { x = 1; y = 0; return a; }
  23. ll d = exgcd(b, a % b, x, y), z = x; x = y; y = z - y * (a / b);
  24. return d;
  25. }
  26. ll inv(ll a, ll b) {
  27. ll x, y; ll d = exgcd(a, b, x, y);
  28. return d == 1 ? (x % b + b) % b : -1;
  29. }
  30. ll CRT(ll *m, ll *a, int n) {
  31. ll x = a[1], M = m[1];
  32. for (int i = 2; i <= n; i ++) {
  33. ll c = a[i] - x, d = gcd(M, m[i]);
  34. if (c % d) return -1;
  35. ll k = (c / d) * inv(M / d, m[i] / d) % (m[i] / d);
  36. x += k * M; M *= m[i] / d;
  37. }
  38. return (x % M + M) % M;
  39. }
  40. int main() {
  41. while (~scanf("%d", &n)) {
  42. for (int i = 1; i <= n; i ++) read(m[i]), read(a[i]);
  43. ll res = CRT(m, a, n);
  44. writeln(res);
  45. }
  46. return 0;
  47. }

「POJ2891」Strange Way to Express Integers【数学归纳法,扩展中国剩余定理】的更多相关文章

  1. POJ2891 Strange Way to Express Integers【扩展中国剩余定理】

    题目大意 就是模板...没啥好说的 思路 因为模数不互质,所以直接中国剩余定理肯定是不对的 然后就考虑怎么合并两个同余方程 \(ans = a_1 + x_1 * m_1 = a_2 + x_2 * ...

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

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

  3. POJ-2891 Strange Way to Express Integers(拓展中国剩余定理)

    放一个写的不错的博客:https://www.cnblogs.com/zwfymqz/p/8425731.html POJ好像不能用__int128. #include <iostream> ...

  4. 【POJ2891】Strange Way to Express Integers(拓展CRT)

    [POJ2891]Strange Way to Express Integers(拓展CRT) 题面 Vjudge 板子题. 题解 拓展\(CRT\)模板题. #include<iostream ...

  5. 【poj2891】 Strange Way to Express Integers

    http://poj.org/problem?id=2891 (题目链接) 题意 求解线性同余方程组,不保证模数一定两两互质. Solotion 一般模线性方程组的求解,详情请见:中国剩余定理 细节 ...

  6. 【poj2891】Strange Way to Express Integers

    题意: 给出n个模方程x=a(mod r) 求x的最小解 题解: 这就是个线性模方程组的模版题- - 但是有一些要注意的地方 extgcd算出来的解x可能负数  要让x=(x%mo+mo)%mo 而且 ...

  7. POJ2891:Strange Way to Express Integers(解一元线性同余方程组)

    写一下自己的理解,下面附上转载的:若a==b(modk);//这里的==指的是同余,我用=表示相等(a%k=b)a-b=kt(t为整数)以前理解的错误思想:以前认为上面的形式+(a-tb=k)也是成立 ...

  8. POJ2891:Strange Way to Express Integers——题解

    http://poj.org/problem?id=2891 题目大意: k个不同的正整数a1,a2,...,ak.对于一些非负m,满足除以每个ai(1≤i≤k)得到余数ri.求出最小的m. 输入和输 ...

  9. POJ 2891 Strange Way to Express Integers【扩展欧几里德】【模线性方程组】

    求解方程组 X%m1=r1 X%m2=r2 .... X%mn=rn 首先看下两个式子的情况 X%m1=r1 X%m2=r2 联立可得 m1*x+m2*y=r2-r1 用ex_gcd求得一个特解x' ...

随机推荐

  1. Rxjs常用operators

    本文使用的是angular6内置的rxjs,版本号为6.3.3 concat 通过顺序地发出多个 Observables 的值将它们连接起来,一个接一个的. 参数: 名称 类型 属性 描述 other ...

  2. centos服务器如何监控访问ip,并将非法ip通过防火墙禁用

    centos服务器如何监控访问ip,并将非法ip通过防火墙禁用 上周给朋友帮忙,上架了一款小游戏(年年有鱼),项目刚一上线,就遇到了ddos攻击,阿里云连续给出了6次ddos预警提示,服务器一度处于黑 ...

  3. Maven的基础了解与使用

    目录 Maven的介绍: 什么是Maven: 为什么要学习maven? 安装与配置: 下载: 配置环境变量 测试安装结果: Maven概念: 坐标 仓库 入门示例 创建maven工程: 添加依赖 Ma ...

  4. MongoDB 创建索引的语法

    1.为普通字段添加索引,并且为索引命名 db.集合名.createIndex( {"字段名": 1 },{"name":'idx_字段名'}) 说明: (1)索 ...

  5. 字符是否为SQL的保留字

    要想知道字符是否为MS SQL Server保留字,那我们必须把SQL所有保留字放在一个数据集中.然后我们才能判断所查找的字符是否被包含在数据集中. MS SQL Server保留字: ) = 'ad ...

  6. 数据库之redis篇(1)—— redis数据库安装,简单使用

    简介 reids,由Salvatore Sanfilippo写的一个高性能的key-value数据库,并且它是非关系型数据库,也就是没有像mysql那样多表链接操作,并且它是是完全开源免费的,遵守BS ...

  7. Delphi Record To Stream

    type TUserInfo = record sUserId,sUserName:String; iUserCount:integer; end; procedure TForm1.Button1C ...

  8. 关于c#(vs)dategridview控件继承不能修改的问题

    问题描述:前几天写个小项目的时候,用到了一个父窗体,然后继承过来的dategridview控件不管是属性还是事件都不能修改. 如下图所示: 然后我就在网上找资料,但是有关这个问题的资源甚少,或许是我不 ...

  9. python网络进阶篇

    并发编程 进程 操作系统的历史 # 手工操作 —— 穿孔卡片 # 程序员将对应于程序和数据的已穿孔的纸带(或卡片)装入输入机,然后启动输入机把程序和数据输入计算机内存,接着通过控制台开关启动程序针对数 ...

  10. 关于创建本地docker仓库

    从远程仓库中下载regitstry镜像文件,下载后运行命令即可:docker run -p 5000:5000 -d registry