news 2026/3/29 1:40:49

信息学奥赛一本通 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/3/24 13:46:05

41、树莓派硬件接口与软件应用全解析

树莓派硬件接口与软件应用全解析 1. Gertboard编程 Gertboard编程与底层Arduino代码颇为相似,都是直接对内存映射的输入输出(IO)进行操作,这就要求具备汇编程序员的精细技能。以下是一段示例代码: PWMCLK_DIV = 0x5A000000 | (32<<12); PWMCLK_CNTL = 0x5A0000…

作者头像 李华
网站建设 2026/3/28 11:02:23

13、SAS 输出控制与共享库访问指南

SAS 输出控制与共享库访问指南 1. 过程输出选项 在 SAS 中,有一系列系统选项可用于控制过程输出的内容,以下是这些选项的详细介绍: | 选项 | 描述 | 默认设置 | | — | — | — | | SOURCE2 / NOSOURCE2 | 控制使用 %INCLUDE 语句包含的 SAS 语句是否写入日志。 | NOSO…

作者头像 李华
网站建设 2026/3/26 9:10:36

15、从SAS访问共享可执行库及远程浏览相关知识

从SAS访问共享可执行库及远程浏览相关知识 1. 从SAS访问共享可执行库示例 在SAS中访问共享可执行库有多种应用场景,下面通过具体示例进行说明。 1.1 更新字符串参数 该示例使用Solaris提供的共享库 libc.so 中的 tmpnam 例程,此库安装在 /usr/lib/sparcv9 目录下。…

作者头像 李华
网站建设 2026/3/28 16:32:50

17、SAS窗口环境操作指南

SAS窗口环境操作指南 1. 窗口与工具栏的打开和关闭 1.1 命令窗口 打开步骤 : 在“首选项”对话框的“工具箱”选项卡中,取消选择“合并窗口”。 完成以下任意步骤: 在“首选项”对话框的“工具箱”选项卡中选择“显示命令窗口”。 发出“COMMAND WINDOW”命令。 关闭…

作者头像 李华
网站建设 2026/3/27 6:58:06

22、深入解析UNIX环境下SAS窗口环境的定制

深入解析UNIX环境下SAS窗口环境的定制 1. 资源查找与对比度控制 SAS查找默认CPARMS资源的位置有两个: - 若现场SAS支持人员在SASHELP.BASE.SAS.CPARMS目录条目中输入了颜色和属性设置,那么这些设置将成为站点的默认设置。 - 若你将设置保存在SASUSER.PROFILE.SAS.CPARMS中…

作者头像 李华
网站建设 2026/3/26 10:52:57

27、SAS在UNIX环境下的语句详解

SAS在UNIX环境下的语句详解 1. 概述 在UNIX环境中使用SAS时,部分SAS语句具有特定的行为或语法。下面将详细介绍这些语句。 2. 部分重要语句介绍 2.1 ABORT语句 功能 :停止执行当前的DATA步骤、SAS作业或SAS会话。 有效范围 :在DATA步骤中。 UNIX特定 :n的值。 语…

作者头像 李华