设在第 $x$ 天二人都 lucky,则有 $\DeclareMathOperator{\lcm}{lcm}$
$ x = y_a t_a + R_a $
$ x= y_b t_ b + R_b$

约束条件:
$ l_a \le R_a \le r_a$,$l_b \le R_b \le r_b$
$ y_a, y_b \ge 0$

写成同余方程组

\begin{cases}
x \equiv R_a \pmod{t_a} \\
x \equiv R_b \pmod{t_b}
\end{cases}

设 $x_0$ 是上述同余方程组的一个特解,则其通解可表为 $x = x_0 + k\lcm(t_a, t_b)$,$k\in\mathbb Z$ 。

容易证明,同余方程组

\begin{cases}
x \equiv r_1 \pmod{m_1} \\
x \equiv r_2 \pmod{m_2}
\end{cases}
有解的充要条件是 $\gcd(m_1,m_2) \mid (r_1 - r2)$,此充要条件亦可写成 $r_2 = r_1 + k \gcd(m_1,m_2), k\in\mathbb Z$,或者写成 $r_1 \equiv r_2 \pmod{\gcd(m_1,m_2)}$ 。

解法:二分答案。
实现:http://codeforces.com/contest/1055/submission/45569689

总结

求解形如
\begin{equation}
\begin{cases}
x \equiv a_1 \pmod{m_1} \\
x \equiv a_2 \pmod{m_2} \\
\vdots \\
x \equiv a_n \pmod{m_n}
\end{cases} \label{E:0}
\end{equation}
的同余方程组。

考虑两个方程构成的同余方程组
\begin{equation}
\begin{cases}
x \equiv a_1 \pmod{m_1} \\
x \equiv a_2 \pmod{m_2}
\end{cases}\label{E:1}
\end{equation}

\begin{equation}
\begin{cases}
x = m_1 s + a_1 \\
x = m_2 t + a_2
\end{cases}\label{E:2}
\end{equation}
$s, t$ 满足方程
\begin{equation}
m_1 s + a_1 = m_2 t + a_2 \label{E:3}
\end{equation}
根据裴蜀定理,\eqref{E:3} 有解的充要条件是 $\gcd(m_1,m_2)\mid (a_1 - a_2)$ 。以下假设此条件成立,并令 $d = \gcd(m_1,m_2)$ 。\eqref{E:3} 亦可写成
\begin{equation}
m_1 s = m_2 t + (a_2 - a_1) \label{E:4}
\end{equation}
方程 \eqref{E:4} 等价于
\begin{equation}
m_1 s \equiv a_2 - a_1 \pmod{m_2}\label{E:5}
\end{equation}
注意:一个不定方程等价于一个同余方程。要熟悉这两种形式的相互转化。
方程 \eqref{E:5} 又等价于
\begin{equation}
\frac{m_1}{d} s \equiv \frac{a_2 - a_1}{d} \pmod{ \frac{m_2}{d} } \label{E:6}
\end{equation}
解得
\begin{equation*}
s \equiv \left(\frac{m_1}{d}\right)^{-1}\frac{a_2 - a_1}{d} \pmod{ \frac{m_2}{d} } \label{E:7}
\end{equation*}
其中 $\left(\frac{m_1}{d}\right)^{-1}$ 表示 $\frac{m_1}{d}$ 在模 $ \frac{m_2}{d} $ 下的逆元,可用扩展欧几里得算法求得。令 $ b = \left(\frac{m_1}{d}\right)^{-1}\frac{a_2 - a_1}{d} $,有
\begin{equation}
s = k \frac{m_2}{d} + b \label{E:8}
\end{equation}
将 \eqref{E:8} 代入 \eqref{E:2},得
\begin{equation}
x = k \frac{m_1m_2}{d} + m_1 b + a_1 \label{E:9}
\end{equation}

\begin{equation}
x \equiv m_1 b + a_1 \pmod{ \frac{m_1 m_2}{d}} \label{E:10}
\end{equation}
至此,我们将同余方程组 \eqref{E:1} 化成了等价(同解)的同余方程 \eqref{E:10} 。

我们证明了

若 \eqref{E:1} 有解,则其在模 $\lcm(m_1,m_2)$ 下有唯一解 $x_0 $。

故可用 $x \equiv x_0 \pmod{\lcm(m_1,m_2)}$ 取代 \eqref{E:0} 中的前两个方程,不断如此操作,最后将得到 $x \equiv a \pmod{\lcm(a_1, a_2, \dots, a_m)}$,这样就得到了 \eqref{E:0} 的通解,也意味着

若 \eqref{E:0} 有解,则其在模 $\lcm(m_1,m_2, \dots, m_n)$ 下有唯一解。

后记

Miskcoo 的文章 从 \eqref{E:3} 的特解和通解入手证明了 \eqref{E:2} 在模 $\lcm(m_1,m_2)$ 下有唯一解,其思路更为简洁。

用扩展 Euclid 算法求出 \eqref{E:3} 的特解 $s',t'$,即可得到 \eqref{E:2} 的特解 $x_0 = s'm_1 + a_1$,然后用 $x \equiv x_0 \pmod{\lcm(m_1, m_2)}$ 替换 \eqref{E:0} 中的前两个方程。

Reference

https://blog.csdn.net/qq_29980371/article/details/71053219

http://blog.miskcoo.com/2014/09/chinese-remainder-theorem

Mail.Ru Cup 2018 Round 2 Problem C Lucky Days的更多相关文章

  1. 【Mail.Ru Cup 2018 Round 2 C】 Lucky Days

    [链接] 我是链接,点我呀:) [题意] [题解] 题解的作者: manish_joshi 对于任意一个k 因为那条直线(关于x,y的方程可以看出一条直线)的斜率>= 所以肯定会经过第一象限. ...

  2. [codeforces Mail.Ru Cup 2018 Round 3][B Divide Candies ][思维+数学]

    https://codeforces.com/contest/1056/problem/B 题意:输入n,m    求((a*a)+(b*b))%m==0的(a,b)种数(1<=a,b<= ...

  3. [codeforces Mail.Ru Cup 2018 Round 1 D][ xor 操作]

    http://codeforces.com/contest/1054/problem/D 题目大意:一个序列a1 a2...an,可以对若干个元素进行取反,使所得的新序列异或和为0的区间个数最多. 题 ...

  4. Mail.Ru Cup 2018 Round 3 B. Divide Candies

    题目链接 分析一下题意可以得到题目要求的是满足下面这个 公式的不同的i,ji,ji,j的方案数; 即(i2+j2)mod&ThinSpace;&ThinSpace; m=0 (n ≤  ...

  5. Mail.Ru Cup 2018 Round 3

    A:签到 #include<iostream> #include<cstdio> #include<cmath> #include<cstdlib> # ...

  6. Mail.Ru Cup 2018 Round 2

    A:阅读理解. #include<iostream> #include<cstdio> #include<cmath> #include<cstdlib> ...

  7. Mail.Ru Cup 2018 Round 2 Solution

    A. Metro Solved. 题意: 有两条铁轨,都是单向的,一条是从左往右,一条是从右往左,Bob要从第一条轨道的第一个位置出发,Alice的位置处于第s个位置,有火车会行驶在铁轨上,一共有n个 ...

  8. Mail.Ru Cup 2018 Round 3 Solution

    A. Determine Line Water. #include <bits/stdc++.h> using namespace std; ]; int main() { while ( ...

  9. Mail.Ru Cup 2018 Round 1

    A. Elevator or Stairs? 签. #include <bits/stdc++.h> using namespace std; ]; int main() { while ...

随机推荐

  1. 2754: C++习题-快速排序

    2754: C++习题-快速排序 Time Limit: 1 Sec  Memory Limit: 128 MBSubmit: 921  Solved: 406[Submit][Status][Web ...

  2. display :inline-block 处理点小障碍

    使用inline-block之前先处理点小障碍:inline-block元素会有4px左右的空隙,这个是因为我们写代码时候的换行符所致. 解决办法很简单:在inline-block的父元素中设置样式f ...

  3. C++ 限定名称查找

    限定名称查找规则实际归纳下来很简单,先对::左边的名称进行查找(遵循,限定,无限定),然后在左边查找到的(此时只查找类型名称)名字的作用域内(含内联名称空间件)查找右边出现的名字,查找到即存在(故可以 ...

  4. AIDE

    安装 yum install aide 修改配置文件 vim /etc/aide.conf (指定对哪些文件进行检测) /test/chameleon R /bin/ps R+a /usr/bin/c ...

  5. 在生产环境下实现每天自动备份mysql数据库

    1.描述 我相信很多朋友在工作都都会有这种需求,老板或领导让你每天都要备份mysql数据库,你该如何实现呢,是每天到一定的时间在服务器上敲一遍mysql的备份命令,还是想写个脚本,定时定点的自动备份呢 ...

  6. DeepFaceLab报错, Could not create cudnn handle 解决方法!

    DeepFaceLab 虽然没有可视化界面,但是在众多换脸软件中,是安装最方便,更新最快,整体性能最佳的一个.这个软件对于系统依赖很低,也就是不需要装各种各样的“插件”. 但是即便如此,由于版本的不断 ...

  7. 内存管理小结(2)--伙伴系统API

    伙伴系统分配内存以2的整数幂次的页数为单位.提供的API主要分为分配类与释放类. 1.分配类 1.1unsigned long __get_free_pages(gfp_t gfp_mask, uns ...

  8. [BSOJ2684]锯木厂选址(斜率优化)

    Description 从山顶上到山底下沿着一条直线种植了n棵老树.当地的政府决定把他们砍下来.为了不浪费任何一棵木材,树被砍倒后要运送到锯木厂.木材只能按照一个方向运输:朝山下运.山脚下有一个锯木厂 ...

  9. V4L2学习(一)整体说明

    1.概述 Video4Linux2是Linux内核中关于视频设备的内核驱动框架,为上层的访问底层的视频设备提供了统一的接口.凡是内核中的子系统都有抽象底层硬件的差异,为上层提供统一的接口和提取出公共代 ...

  10. HDU1272小希的迷宫

    小希的迷宫 上次Gardon的迷宫城堡小希玩了很久(见Problem B),现在她也想设计一个迷宫让Gardon来走.但是她设计迷宫的思路不一样,首先她认为所有的通道都应该是双向连通的,就是说如果有一 ...