Codeforces 986F - Oppa Funcan Style Remastered(同余最短路)
感谢此题教会我一个东西叫做同余最短路(大雾
首先这个不同 \(k\) 的个数 \(\le 50\) 这个条件显然是让我们对每个 \(k\) 进行一遍预处理并快速求出答案。怎么预处理呢?首先考虑一个非常 trivial 的性质,那就是所有 \(k\) 的非质数因子显然可以表示成质因子的和对吧,所以一个数能够表示成 \(k\) 的若干个质因子的和,当且仅当它能够表示成 \(k\) 的若干个质因子的和。因此考虑先对 \(k\) 进行一遍质因数分解——可以使用 PR 算法,但是我不会,每次 \(\sqrt{k}\) 地分解会超时,这里有一个简单的技巧,之前暑假某场模拟赛出现过,就是显然我们只会用到 \(\le\sqrt{k}\) 的所有质因子,因此可以考虑预处理出 \(\le \sqrt{10^{15}}\) 的所有质数,然后每次分解遍历一遍这个质数集合即可,这样分解的复杂度可以降到 \(\sqrt{10^{15}}·\dfrac{1}{\ln 10^{15}}·50\)。
考虑怎样计算答案,如果 \(k\) 本身就是质数那显然只有 \(k\) 的倍数能够表示成 \(k\) 的 \(\ne 1\) 的质因子之和。直接判断一下 \(n\bmod k=0\) 是否成立即可。如果 \(k\) 有两个质因子,那么假设 \(k\) 两个质因子分别为 \(x,y\),那么我们需检验是否 \(\exists a,b\in[0,\infty)\cap\mathbb{Z},s.t.ax+by=n\),显然必须有 \(by\equiv n\pmod{x}\),那么 \(b\) 的最小值 \(b_{\min}=n·y^{-1}\bmod x\),检验一下是否有 \(b_{\min}·y\le n\) 即可。
如果 \(k\) 质因子个数 \(\ge 3\),那么假设 \(k\) 的质因子分别为 \(p_1,p_2,\cdots,p_m\),那么我们需检验是否 \(\exists x_1,x_2,\cdots,x_m\in[0,\infty)\cap\mathbb{Z},s.t.\sum\limits_{i=1}^mp_ix_i=n\),直接检验貌似有点棘手,不过不难发现有一个性质,那就是对于任意 \(x_i\) 及 \(n\),如果 \(n\) 可行,那么 \(n+zp_i\) 也可行,也就是说对于所有 \(j\in[0,p_i)\),必然存在一个界 \(lim_j\),满足所有 \(\bmod x_i=j\) 的数当中,所有 \(\ge lim_j\) 的数都符合要求,所有 \(<lim_j\) 的数都符合要求,考虑怎样求 \(lim_j\),显然 \(lim_0=0\),而对于所有 \(j\in[0,x_i),t\in[1,m]\),显然 \(lim_{(j+p_t)\bmod p_1}\le lim_j+p_t\),这是一个最短路的形式,用 dijkstra 转移即可。并且不难发现对于 \(k\le 10^{15}\),这种情况下 \(k\) 最小的质因子必然 \(\le 10^5\),因此我们对 \(k\) 最小质因子跑同余最短路即可实现 \(10^5\log 10^5·50\) 的复杂度。
话说这场的 D、E,尤其是那个恶心无比的 D……勾起了远古回忆
const int MAXN=1e4;
const int MAXK=1e5;
const int MAXV=3.163e7;
int qpow(int x,int e,int mod){
int ret=1;
for(;e;e>>=1,x=1ll*x*x%mod) if(e&1) ret=1ll*ret*x%mod;
return ret;
}
int qu,pr[MAXV/8+5],prcnt,vis[MAXV+5];
void sieve(int n){
for(int i=2;i<=n;i++){
if(!vis[i]) pr[++prcnt]=i;
for(int j=1;j<=prcnt&&pr[j]*i<=n;j++){
vis[pr[j]*i]=1;if(i%pr[j]==0) break;
}
}
}
int res[MAXN+5];
map<ll,vector<pair<ll,int> > > mpv;
vector<ll> decomp(ll v){
vector<ll> ret;
for(int i=1;i<=prcnt;i++) if(v%pr[i]==0){
ret.pb(pr[i]);
while(v%pr[i]==0) v/=pr[i];
} if(v>1) ret.pb(v);
return ret;
}
ll dis[MAXK+5];
int main(){
sieve(MAXV);scanf("%d",&qu);
for(int i=1;i<=qu;i++){
ll n,k;scanf("%lld%lld",&n,&k);
if(k!=1) mpv[k].pb(mp(n,i));
}
for(auto it:mpv){
ll v=it.fi;vector<pair<ll,int> > qv=it.se;
vector<ll> pr=decomp(v);
if(pr.size()==1){
for(pair<ll,int> p:qv) res[p.se]=(p.fi%pr[0]==0);
} else if(pr.size()==2){
ll x=pr[0],y=pr[1],ivy=qpow(y%x,x-2,x);
for(pair<ll,int> p:qv){
int bmin=1ll*(p.fi%x)*ivy%x;
res[p.se]=(p.fi>=1ll*bmin*y);
}
} else {
int x=pr[0];memset(dis,63,sizeof(dis));dis[0]=0;
priority_queue<pair<ll,int>,vector<pair<ll,int> >,greater<pair<ll,int> > > q;
q.push(mp(0,0));
while(!q.empty()){
pair<ll,int> p=q.top();q.pop();
int cur=p.se;
for(int i=1;i<pr.size();i++){
if(dis[(cur+pr[i])%x]>dis[cur]+pr[i]){
dis[(cur+pr[i])%x]=dis[cur]+pr[i];
q.push(mp(dis[(cur+pr[i])%x],(cur+pr[i])%x));
}
}
}
for(pair<ll,int> p:qv) res[p.se]=(p.fi>=dis[p.fi%x]);
}
}
for(int i=1;i<=qu;i++) printf("%s\n",(res[i])?"YES":"NO");
return 0;
}
Codeforces 986F - Oppa Funcan Style Remastered(同余最短路)的更多相关文章
- [Codeforces 485F] Oppa Funcan Style Remastered
[题目链接] https://codeforces.com/contest/986/problem/F [算法] 不难发现 , 每个人都在且仅在一个简单环中 , 设这些环长的长度分别为 A1, A2 ...
- CF986F Oppa Funcan Style Remastered
CF986F Oppa Funcan Style Remastered 不错的图论转化题! 题目首先转化成:能否用若干个k的非1因数的和=n 其次,因数太多,由于只是可行性,不妨直接都用质因子来填充! ...
- 「CF986F」 Oppa Funcan Style Remastered
「CF986F」 Oppa Funcan Style Remastered Link 首先发现分解成若干个 \(k\) 的因数很蠢,事实上每个因数都是由某个质因子的若干倍组成的,所以可以将问题转换为分 ...
- [CF986F]Oppa Funcan Style Remastered[exgcd+同余最短路]
题意 给你 \(n\) 和 \(k\) ,问能否用 \(k\) 的所有 \(>1\) 的因子凑出 \(n\) .多组数据,但保证不同的 \(k\) 不超过 50 个. \(n\leq 10^{1 ...
- codeforces986F Oppa Funcan Style Remastered【线性筛+最短路】
容易看出是用质因数凑n 首先01个因数的情况可以特判,2个的情况就是ap1+bp2=n,b=n/p2(mod p1),这里的b是最小的特解,求出来看bp2<=n则有解,否则无解 然后剩下的情况最 ...
- Codeforces 516E - Drazil and His Happy Friends(同余最短路)
Codeforces 题面传送门 & 洛谷题面传送门 首先思考一个非常简单的性质:记 \(d=\gcd(n,m)\),那么每次在一起吃完饭的男女孩编号必定与 \(d\) 同余,而根据斐蜀定理可 ...
- 【66测试20161115】【树】【DP_LIS】【SPFA】【同余最短路】【递推】【矩阵快速幂】
还有3天,今天考试又崩了.状态还没有调整过来... 第一题:小L的二叉树 勤奋又善于思考的小L接触了信息学竞赛,开始的学习十分顺利.但是,小L对数据结构的掌握实在十分渣渣.所以,小L当时卡在了二叉树. ...
- HDU 6071 Lazy Running (同余最短路 dij)
Lazy Running Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 524288/524288 K (Java/Others)To ...
- BZOJ 2118 墨墨的等式 (同余最短路)
题目大意:已知B的范围,求a1x1+a2x2+...+anxn==B存在非负正整数解的B的数量,N<=12,ai<=1e5,B<=1e12 同余最短路裸题 思想大概是这样的,我们选定 ...
随机推荐
- SpringCloud微服务实战——搭建企业级开发框架(二):环境准备
这里简单说明一下在Windows系统下开发SpringCloud项目所需要的的基本环境,这里只说明开发过程中基础必须的软件,其他扩展功能(Docker,k8s,MinIO,XXL-JOB,EKL,Ke ...
- 【UE4 设计模式】命令模式 Command Pattern
概述 描述 将一个请求封装为一个对象,从而使我们可用不同的请求对客户进行参数化:对请求排队或者记录请求日志,以及支持可撤销的操作. 命令模式是一种对象行为型模式,其别名为动作(Action)模式或事务 ...
- 「刷题」THUPC泛做
刷了一下,写一下. T1. 天天爱射击 可以这样想. 我们二分一下每一块木板在什么时刻被击碎. 然后直接用主席树维护的话是\(O(nlog^2n)\)的. 会\(T\),而且是一分不给那种... 那么 ...
- 从零开始的DIY智能家居 - 基于 ESP32 的土壤湿度传感器
前言 自从上次做了那个 甲醛传感器 和 水浊度传感器 之后开始尝到智能家居的甜头了,这两东西有没有用我不知道,但是没事的时候掏出手机瞄两眼,看着就让人很安心( ̄︶ ̄). 于是懒惰的我开始琢磨把给植物浇 ...
- Des加密解密(公共方法)
1 public class Des 2 { 3 public static string Encrypt(string message, string key) 4 { 5 DES des = ne ...
- Codeforces Round #736 (Div. 2)
A,B,C就不说了,又被D题卡住了..... 感觉怎么说呢,就是题解中的三个提示都已经想到了,就是不知道该怎么解决.... D. Integers Have Friends 简述题意:题目要求你找一个 ...
- Oracle 11G单机 无网络环境静默安装
参考文章https://blog.csdn.net/xiaoyu19910321/article/details/89856514 环境centos 7.6最小化安装 1,关闭防护墙selinux,配 ...
- Linux 文本三剑客之 sed
Linux 系统中一切皆文件. 文件是个文本.可以读.可以写,如果是二进制文件,还能执行. 在使用Linux的时候,大都是要和各式各样文件打交道.熟悉文本的读取.编辑.筛选就是linux系统管理员的必 ...
- Fiddler抓包工具简介:(四)Fiddler的基本使用
Fiddler的使用 视图功能区域 会话的概念:一次请求和一次响应就是一个会话. fiddler主界面 下面挑几个快捷功能区中常用几项解释,其他功能自己尝试: 快捷功能区 1:给会话添加备注信息 2: ...
- VUE的MVVM框架解析
这篇文章主要介绍了MVVM模式中ViewModel和View.Model有什么区别?本文分别解释了它们的功能和作用,然后总结了它之间的区别,需要的朋友可以参考下 Model:很简单,就是业务逻辑相关的 ...