CF687B 题解

news/2025/3/13 18:28:54/文章来源:https://www.cnblogs.com/theshumo/p/18770537

分析

化简题意,可以看作为

\[\begin{cases} x \equiv p_1 \pmod {m_1} \\ x \equiv p_2 \pmod {m_2} \\ \;\;\;\;\vdots \\ x \equiv p_n \pmod {m_n} \end{cases} \]

问能否求出 \(x \bmod k\) 的值。

由于题目中并没有给定 \(m_1,m_2,m_3,\cdots,m_n\) 是否互质,运用中国剩余定理是无法解决的。

对于仅有两个同余方程的方程组:

\[\begin{cases} x\equiv p_1 \pmod {m_1}\\ x \equiv p_2 \pmod{m_2} \end{cases}\tag{1} \]

我们可以把它化为这样的形式:

\[x = k_1m_1 +p_1= k_2 m_2 + p_2 \tag{2} \]

移项,得:

\[k_1m_1 -k_2m_2 = p_2-p_1 \tag{3} \]

这就是一个典型的二元一次不定方程。根据裴蜀定理,有:

  1. \(\gcd(m_1,m_2) \mid (p_2-p_1)\) 则原方程有解。
  2. 否则,原方程无解。

假设原方程有解,即 \(\gcd(m_1,m_2)\mid (p_2,p_1)\),设 \(d=\gcd(m_1,m_2)\)
\((3)\) 式等价于 $$m_1k_1 \equiv p_2-p_1 \pmod {m_2} \tag{4}$$
等价于 $$\frac{m_1k_1}{d} \equiv \frac{p_2-p_1}{d} \pmod{\frac{m_2}{d}} \tag{5}$$
解得 $$k_1 \equiv (\frac{m_1}{d})^{-1}\times \frac{p_2-p_1}{d}\pmod{\frac{m_2}{d}} \tag{6}$$
即 $$k_1=k\frac{m_2}{d} + (\frac{m_1}{d})^{-1}\times \frac{p_2-p_1}{d} \tag{7}$$
\((7)\) 式代入 \((1)\) 式中,可得 $$x = k\frac{m_1m_2}{d} +m_1(\frac{m_1}{d})^{-1}\times \frac{p_2-p_1}{d} + p_1 \tag{8}$$
\((8)\) 式又等价于 $$x \equiv m_1(\frac{m_1}{d})^{-1}\times \frac{p_2-p_1}{d} + p_1 \pmod{\frac{m_1m_2}{d}}\tag{9}$$
\((\frac{m_1}{d})^{-1}\times \frac{p_2-p_1}{d} = b\),因为 \(\operatorname{lcm}(m_1,m_2)=\frac{m_1m_2}{\gcd(m_1,m_2)}\),所以 \((9)\) 式等于 $$x \equiv m_1b + p_1\pmod{\operatorname{lcm}(m_1,m_2)} \tag{10}$$
自此,我们证明了:若 \((1)\) 式有解,那么它在模 \(\operatorname{lcm}(m_1,m_2)\) 下有唯一解。
进而,对于有任意多个的,模数不互质的同余方程组,若它有解,那么它在模 \(\operatorname{lcm}(m_1,m_2,\cdots,m_n)\) 的意义下也有唯一解。
推导方法很简单,提取出前两个式子化成 \((10)\) 式的样子,放回去,根据 \(\operatorname{lcm}(\operatorname{lcm}(m_1,m_2),m_3) = \operatorname{lcm}(m_1,m_2,m_3)\) 一个个推就得到令最终的答案。

思路类似 P4777 扩展中国剩余定理,大家看完可以去做做。

代码

#include<bits/stdc++.h>
#define int long longnamespace IO {#define int long long #define gh getcharinline int read(){char ch=gh();int x=0;bool t=0;while(ch<'0'||ch>'9')   t|=ch=='-',ch=gh();while(ch>='0'&&ch<='9') x=x*10+(ch^48),ch=gh();return t?-x:x;}inline char getc(){char ch=gh();while(ch<'a'||ch>'z') ch=gh();return ch;}inline void write(int x){if(x < 0){putchar('-');x = -x;}if(x > 9){write(x / 10);}putchar((x % 10 + '0'));}
}
using namespace IO;
using namespace std;
const int Maxn = 100010;
int c[Maxn];
int gcd(int a,int b){if(a%b == 0)return b;return gcd(b,a%b);
}
signed main(){int n = read(), k = read();for(int i = 1; i <= n; i++)c[i] = read();int lcm = 1;for(int i = 1; i <= n; i++){lcm = lcm * c[i] / gcd(lcm,c[i]);lcm %= k;}if(lcm == 0)return puts("Yes");return puts("No");
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/898291.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

[算法学习记录] 并查集(附例题)

并查集简介 并查集是一种重要的数据结构,主要用于实现节点之间的合并查询操作(例如判断两个节点是否属于同一个连通块(共享同一个父节点的节点组成的集合叫连通块)),在解决不相交集合时有很大的用处;并查集同样常用于处理无向图,来描述接点的连通性,在初始化时,每个节…

Electron 进程间通信(IPC)方法详解

Electron 是一个使用 JavaScript、HTML 和 CSS 构建桌面应用程序的框架,它是基于 Chromium 和 Node.js 构建的,而 Chromium 本身是采用多进程架构的,所以 Electron 也是多进程的。 Electron 是一个多进程框架,它的进程主要分为两类:主进程(Main Process) 和 渲染进程(R…

从零开始的web前端学习-JavaScript

JavaScript 是一种运行在客户端(浏览器)的编程语言,实现人机互动效果:网页特效(监听用户的某些行为并令网页进行反馈) 表单验证(针对表单数据的合法性进行判断) 数据交互(获取后台数据并渲染到前端)JavaScript 组成ECMAScript:基础语法核心 Web APIs:DOM(页面文档…

【Azure Service Bus】分享使用 Python Service Bus SDK 输出SDK内操作日志

问题描述 使用Python代码消费Service Bus中的消息,默认情况 Console 中的信息都是通过 print 打印输出。 有时候需要调查更多SDK中的日志,那么如何才能让SDK输出更多的日志呢?问题解答 方法就是引入 Logging SDK,然后再初始化 ServiceBusClient 对象时,设置logging_enabl…

nvm和nodejs安装

nvm和nodejs安装安装 nvm 全名 node.js version management,顾名思义是一个nodejs的版本管理工具。通过它可以安装和切换不同版本的nodejs。首先下载安装包,可以用GitHub上的,可以有点看,也可以用一些镜像,然后点击安装一直下一步即可。 然后打开命令行,可以用nvm -v指令…

dify文件上传到http节点

dify系统上传sys.files变量是Array[File]类型,由于 HTTP 请求节点不支持 Array[File] 上传,需要单独处理每个文件,以下是实现此功能的步骤: 添加迭代节点 迭代输入选sys.files 输出选http请求body http请求body类型选form-data 键值选迭代的item.File 本文使用dify版本为0.…

可行性分析(第五组)

目录 第1章 系统分析 1.1 可行性分析 1.1.1 技术可行性分析 1.1.2 经济可行性分析 1.1.3 社会可行性分析 1.1.4 法律可行性分析 1.2 系统流程分析 1.2.1 系统开发总流程 1.2.2 登录流程 1.2.3 系统操作流程 1.2.4 系统性能分析 第1章 可行性分析 1.1可行性分析 下面分别从技术可…

C# 子窗体中调用父窗体中的方法(或多窗体之间方法调用)

看似一个简单的功能需求,其实很多初学者处理不好的,很多朋友会这么写:C# Code://父窗体是是frmParent,子窗体是frmChildA //在父窗体中打开子窗体 frmChildA child = new frmChildA(); child.MdiParent = this; child.Show();//子窗体调父窗体方法: //错误的调用!!!!!!!! …

Qt HTTP模块——调用API对话DeepSeek

HTTP模块 Qt的网络模块(QtNetwork)支持HTTP/HTTPS协议,提供异步、非阻塞的API,实现客户端与服务器之间的 HTTP 请求与响应交互。核心类:QNetworkAccessManager:负责协调网络操作(如GET/POST请求),管理请求队列和返回的响应。 QNetworkRequest:封装HTTP请求的详细信息…

Linux下环境变量

Linux打印环境变量: echo $PATH

GitLearning

创建新仓库 创建新文件夹,打开,然后执行 git init创建新的 git 仓库 (也可以直接 git clone 远程仓库) git clone /path/to/repository git clone username@host:/path/to/repository工作流 本地仓库由 git 维护的三棵树。第一个是工作目录,它持有实际文件;第二个是暂存区(…