当前位置: 首页 > news >正文

信息学奥赛一本通 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;}
http://www.cnnetsun.cn/news/43628.html

相关文章:

  • 22、家庭网络实用指南:数据备份、隐藏与布线策略
  • 28、通信与数据:实现智能家居的关键要素
  • 04_让浏览器新标签页“重生”——集颜值、效率与 AI 于一体的 WeTab 体验指南
  • 24、UNIX环境下的SAS数据集选项与格式详解
  • 26、UNIX环境下SAS的信息格式、宏功能及过程使用指南
  • 29、SAS系统相关目录、工具及通用命令详解
  • 56、网络信息服务(NIS)与轻量级目录访问协议(LDAP)部署指南
  • 57、Linux LDAP 与 CUPS 系统使用指南
  • ComfyUI与社交平台头像生成结合:个性化IP打造工具
  • ComfyUI中使用Style Transfer节点的艺术化处理
  • 27、基于地理关联数据的用户与位置建模剖析
  • 2.1 Cursor进阶技巧:Rules设置与文档集成全攻略
  • 英伟达数学推理新突破:15亿参数模型性能媲美完整版DeepSeek-R1
  • 10、网络传输与会话管理工具:lftp 与 screen 实用指南
  • 12、提升系统安全性与网络管理:SELinux与网络命令详解
  • 腾讯发布HunyuanWorld-Voyager:单图驱动3D场景生成技术突破,开启沉浸式内容创作新纪元
  • 智谱AI开源力作GLM-4-9B:多维度性能超越Llama-3-8B,开启大模型应用新纪元
  • 6、高增长、高科技企业的商业模式剖析
  • 基于自抗扰控制ADRC的永磁同步电机仿真模型(Simulink仿真实现)
  • 12、Oracle软件安装、配置、故障排除与卸载全解析
  • 技术文档还在全靠 Markdown?它可能真的在拖你后腿
  • 阿里重磅发布HunyuanCustom视频生成模型 多模态技术引领虚拟内容创作新革命
  • OpenAI开源力作:GPT-OSS模型深度解析与应用指南
  • 基于微信小程序的商品展示计算机毕设(源码+lw+部署文档+讲解等)
  • 【Spring】实现验证码功能
  • 人工智能行业发展新趋势:技术突破与应用拓展并行
  • 8、X Window System使用指南
  • Log4j2 + AI 异常分析:当生产环境报错时,让 AI 自动告诉你 Bug 在哪一行(LogAppender 实战)
  • 11、如何使用 PPP 协议连接互联网
  • 12、OpenLinux 系统互联网邮件配置全攻略