news 2026/4/23 2:31:10

信息学奥赛一本通 1634:【例 4】曹冲养猪 | 洛谷 P1495 【模板】中国剩余定理(CRT)/ 曹冲养猪

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
信息学奥赛一本通 1634:【例 4】曹冲养猪 | 洛谷 P1495 【模板】中国剩余定理(CRT)/ 曹冲养猪

【题目链接】

ybt 1634:【例 4】曹冲养猪
洛谷 P1495 【模板】中国剩余定理(CRT)/ 曹冲养猪

【题目考点】

1. 中国剩余定理

有线性同余方程组:
{ x ≡ a 1 ( m o d m 1 ) x ≡ a 2 ( m o d m 2 ) ⋮ x ≡ a n ( m o d m n ) \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}xa1(modm1)xa2(modm2)xan(modmn)
其中m 1 , m 2 , . . . , m n m_1, m_2, ..., m_nm1,m2,...,mn互质。
中国剩余定理可以求解以上线性同余方程组。

  1. M = m 1 m 2 . . . m n M=m_1m_2...m_nM=m1m2...mn,为m 1 m_1m1m n m_nmn的乘积。

  2. q i = M m i q_i=\dfrac{M}{m_i}qi=miM

  3. 线性同余方程组的解为
    x = ∑ i = 1 n a i q i ( q i − 1 m o d m i ) x=\sum_{i=1}^na_iq_i(q_i^{-1} \bmod m_i)x=i=1naiqi(qi1modmi)

证明:
对于任一同余方程x ≡ a k ( m o d m k ) x\equiv a_k \pmod{m_k}xak(modmk)
∑ i = 1 n a i q i ( q i − 1 m o d m i ) m o d m k \sum_{i=1}^na_iq_i(q_i^{-1} \bmod m_i)\bmod m_ki=1naiqi(qi1modmi)modmk

  • i ≠ k i\neq ki=k时,由于m k ∣ M m_k\mid MmkM,且g c d ( m k , m i ) = 1 gcd(m_k, m_i)=1gcd(mk,mi)=1,所以m k ∣ M m i m_k\mid \frac{M}{m_i}mkmiM,即m k ∣ q i m_k\mid q_imkqi
    所以a i q i ( q i − 1 m o d m i ) m o d m k = 0 a_iq_i(q_i^{-1} \bmod m_i)\bmod m_k = 0aiqi(qi1modmi)modmk=0
  • i = k i=ki=k时,a k q k ( q k − 1 m o d m i ) m o d m k = a k m o d m k a_kq_k(q_k^{-1} \bmod m_i)\bmod m_k=a_k\bmod m_kakqk(qk1modmi)modmk=akmodmk
    所以∑ i = 1 n a i q i ( q i − 1 m o d m i ) m o d m k = a k m o d m k \sum_{i=1}^na_iq_i(q_i^{-1} \bmod m_i)\bmod m_k=a_k\bmod m_ki=1naiqi(qi1modmi)modmk=akmodmk
    即当x = ∑ i = 1 n a i q i ( q i − 1 m o d m i ) x=\sum_{i=1}^na_iq_i(q_i^{-1} \bmod m_i)x=i=1naiqi(qi1modmi)时满足x ≡ a k ( m o d m k ) x\equiv a_k \pmod{m_k}xak(modmk)
    因此x = ∑ i = 1 n a i q i ( q i − 1 m o d m i ) x=\sum_{i=1}^na_iq_i(q_i^{-1} \bmod m_i)x=i=1naiqi(qi1modmi)满足该线性同余方程组。
2. 乘法逆元

乘法逆元相关知识见:洛谷 P1082 [NOIP 2012 提高组] 同余方程

【解题思路】

设共有x xx头猪,建a i a_iai个猪圈,b i b_ibi头猪没有去处,那么满足x m o d a i = b i x\bmod a_i = b_ixmodai=bi,写成同余方程,为x ≡ b i ( m o d a i ) x\equiv b_i \pmod{a_i}xbi(modai)
那么本题需要求该同余方程组的解
{ x ≡ b 1 ( m o d a 1 ) x ≡ b 2 ( m o d a 2 ) ⋮ x ≡ b n ( m o d a n ) \begin{cases} x \equiv b_1 \pmod{a_1} \\ x \equiv b_2 \pmod{a_2} \\ \vdots \\ x \equiv b_n \pmod{a_n} \end{cases}xb1(moda1)xb2(moda2)xbn(modan)
可以使用中国剩余定理求解。
注意,在求解过程中表达式的值可能会超出long long类型的表示范围,应该将表达式的值强转为__int128类型(128位整型),完成计算。

【题解代码】

解法1:中国剩余定理
#include<bits/stdc++.h>usingnamespacestd;#defineN15#defineMOD(a,b)(((a)%(b)+(b))%(b))//数学取模 a mod btypedeflonglongLL;voidexgcd(LL a,LL b,LL&x,LL&y)//扩展欧几里得定理{if(b==0){x=1,y=0;return;}exgcd(b,a%b,y,x);y-=a/b*x;}LLinv(LL a,LL m)//求a模m的逆元{LL x,y;exgcd(a,m,x,y);returnMOD(x,m);}LLCRT(LL*a,LL*m,LL n)//x≡a[i] (mod m[i]) i:[1, n]{LL M=1,res=0;for(inti=1;i<=n;++i)M*=m[i];for(inti=1;i<=n;++i)res=(res+(__int128_t)a[i]*M/m[i]*inv(M/m[i],m[i]))%M;returnres;}intmain(){LL n,a[N],b[N];cin>>n;for(inti=1;i<=n;++i)cin>>a[i]>>b[i];cout<<CRT(b,a,n);return0;}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 6:34:02

26、通信:人类交流,计算机通信

通信:人类交流,计算机通信 在当今数字化时代,计算机之间的通信以及人与计算机的交互变得至关重要。本文将深入探讨网络访问、构建Web服务器、虚拟站点、安全服务器以及机器控制等方面的内容。 1. 硬件优势与网络访问 虽然某种屏蔽设备成本较高,但它能处理16位波形,且内…

作者头像 李华
网站建设 2026/4/20 22:15:13

38、智能家居控制与树莓派应用全解析

智能家居控制与树莓派应用全解析 在智能家居的世界里,各种技术和设备相互协作,为我们打造便捷舒适的生活环境。本文将深入探讨Marple系统、相关工具脚本以及网络拓扑结构,同时介绍树莓派在智能家居中的应用。 Marple系统 Marple即Minerva Appliance Routing and ProtocoL…

作者头像 李华
网站建设 2026/4/23 0:07:35

20、定制SAS窗口环境:工具集与按键定义全解析

定制SAS窗口环境:工具集与按键定义全解析 在使用SAS时,为了提高工作效率和满足个性化需求,我们可以对其窗口环境进行定制,包括工具集和按键定义。下面将详细介绍如何进行这些定制操作。 1. 创建和定制工具集与工具箱 1.1 创建新的工具箱 创建全新的工具箱可以按照以下步…

作者头像 李华
网站建设 2026/4/18 16:01:07

58、Linux 打印系统 CUPS 全面指南

Linux 打印系统 CUPS 全面指南 1. CUPS 访问控制配置 在配置 CUPS 时,涉及到一些重要的指令来控制访问权限。以下是相关指令的详细解释: - Location 指令 :定义了所有 GET 操作的路径起点 / ,这是 Web 服务器的最高级别路径。 - Order 指令 :定义了指定位置的默…

作者头像 李华
网站建设 2026/4/22 10:45:29

62、Linux备份全攻略

Linux备份全攻略 1. 磁带操作基础 在Linux中,若不使用非倒带磁带设备,使用 mt 命令操作后磁带驱动器会自动倒带,这在查找特定文件时可能会带来困扰。 以下是一些常见的磁带操作命令: - 倒带 /dev/nst0 中的备份磁带: [root@server ~]# mt -f /dev/nst0 rewind将…

作者头像 李华
网站建设 2026/4/20 8:10:02

40、敏捷开发相关指标与实践解析

敏捷开发相关指标与实践解析 1. Sidky敏捷测量指数(SAMI)反馈 为了收集关于Sidky敏捷测量指数(SAMI)的反馈,向28位敏捷社区成员展示了SAMI,并通过90分钟的个人访谈(单独或分组)获取反馈,访谈包括SAMI的介绍、讨论和填写问卷环节。问卷主要关注SAMI的全面性、实用性、…

作者头像 李华