CF986F Oppa Funcan Style Remastered

不错的图论转化题!

题目首先转化成:能否用若干个k的非1因数的和=n

其次,因数太多,由于只是可行性,不妨直接都用质因子来填充!

即:是否存在ai,使得∑ai*pi=n

经典套路:同余系最短路!

最小质因子p0,n一定是若干p0和其他的数凑出来的

dis[i]表示,%p0=i的数用pi来凑出来,最小是多少。最短路即可。

如果dis[n%p0]<=n,那么一定可以!

把询问离线,按照k依次处理。

一些特殊情况:

k=1,全都是NO

k是质数,特判

k是p1,p2两个质因子,这时最短路点数可能是3e7的,会TLE,于是解不定方程:x*p1+y*p2=n是否有x,y的自然数解。注意很可能爆long long,所以x=(n/g)%(p2/g)*x%(p2/g)

k有三个以上质因子,点数最多1e5,同余系最短路。

质因数分解可以暴力分解,线性筛出根号1e15的质数,总分解复杂度<50*4000000

#include<bits/stdc++.h>
#define reg register int
#define il inline
#define fi first
#define se second
#define mk(a,b) make_pair(a,b)
#define numb (ch^'0')
#define pb push_back
#define solid const auto &
#define enter cout<<endl
#define pii pair<int,int>
using namespace std;
typedef long long ll;
template<class T>il void rd(T &x){
char ch;x=;bool fl=false;while(!isdigit(ch=getchar()))(ch=='-')&&(fl=true);
for(x=numb;isdigit(ch=getchar());x=x*+numb);(fl==true)&&(x=-x);}
template<class T>il void output(T x){if(x/)output(x/);putchar(x%+'');}
template<class T>il void ot(T x){if(x<) putchar('-'),x=-x;output(x);putchar(' ');}
template<class T>il void prt(T a[],int st,int nd){for(reg i=st;i<=nd;++i) ot(a[i]);putchar('\n');}
namespace Modulo{
const int mod=;
int ad(int x,int y){return (x+y)>=mod?x+y-mod:x+y;}
void inc(int &x,int y){x=ad(x,y);}
int mul(int x,int y){return (ll)x*y%mod;}
void inc2(int &x,int y){x=mul(x,y);}
int qm(int x,int y=mod-){int ret=;while(y){if(y&) ret=mul(x,ret);x=mul(x,x);y>>=;}return ret;}
}
//using namespace Modulo;
namespace Miracle{
const int N=1e5+;
const int M=+;
int m;
struct qs{
ll n,k,id;
bool friend operator <(qs a,qs b){
return a.k<b.k;
}
}q[N];
int ans[N];
vector<ll>yin;
int pri[+],cnt;
bool vis[M];
void sieve(int n){
for(reg i=;i<=n;++i){
if(!vis[i]){
pri[++cnt]=i;
}
for(reg j=;j<=cnt;++j){
if(i*pri[j]>n) break;
vis[i*pri[j]]=;
if(i%pri[j]==) break;
}
}
}
ll dis[N];
queue<int>Q;
void spfa(int mod){
memset(dis,0x3f,sizeof dis);
// for(solid y:yin){
// // cout<<" yy "<<y<<endl;
// }
dis[]=;
Q.push();
while(!Q.empty()){
int x=Q.front();Q.pop();vis[x]=;
// cout<<"xx "<<x<<endl;
for(reg i=;i<yin.size();++i){
int y=(x+yin[i])%mod;
if(dis[y]>dis[x]+yin[i]){
dis[y]=dis[x]+yin[i];
if(!vis[y]){
vis[y]=;
Q.push(y);
}
}
}
}
}
void divi(ll K){
yin.clear();
ll tmp=K;
for(reg i=;(ll)pri[i]*pri[i]<=tmp&&i<=cnt;++i){
if(tmp%pri[i]==){
yin.pb(pri[i]);
while(tmp%pri[i]==) tmp/=pri[i];
}
}
if(tmp!=) yin.pb(tmp);
}
ll exgcd(ll a,ll b,ll &x,ll &y){
if(!b){
x=;y=;return a;
}
ll ret=exgcd(b,a%b,y,x);
y-=(a/b)*x;
return ret;
}
int main(){
rd(m);
ll mx=;
for(reg i=;i<=m;++i){
rd(q[i].n);rd(q[i].k);q[i].id=i;
mx=max(mx,q[i].k);
}
mx=sqrt(mx);
sieve(mx);
memset(vis,,mx+);
// prt(vis,0,mx);
sort(q+,q+m+);
int typ=;
for(reg i=;i<=m;++i){
if(q[i].k!=q[i-].k){
divi(q[i].k);
typ=;
if(q[i].k==) typ=;
else if(yin.size()==) typ=;
else if(yin.size()==) typ=;
else{
typ=;
int mod=yin[];
spfa(mod);
}
}
// cout<<" typ "<<typ<<endl;
// prt(dis,0,yin[0]-1);
if(typ==){
ans[q[i].id]=;
}
else if(typ==){
if(q[i].n%yin[]==){
ans[q[i].id]=;
}
}else if(typ==){
// cout<<" typ==2 "<<endl;
ll x,y;
ll g=exgcd(yin[],yin[],x,y);
// cout<<" gg "<<g<<" "<<yin[0]<<" "<<yin[1]<<endl;
// cout<<"st "<<x<<" "<<y<<" : "<<x*yin[0]+y*yin[1]<<endl;
ll md=yin[]/g;
x=(x%md+md)%md;
if(q[i].n%g==){
x=(q[i].n/g)%md*x%md;
y=(q[i].n-x*yin[])/yin[];
// cout<<" x "<<x<<" y "<<y<<endl;
// cout<<" eql "<<x*yin[0]+y*yin[1]<<endl;
if(y>=){
ans[q[i].id]=;
}
}
}else{
if(dis[q[i].n%yin[]]<=q[i].n){
ans[q[i].id]=;
}
}
}
for(reg i=;i<=m;++i){
if(ans[i]) puts("YES");
else puts("NO");
}
return ;
} }
signed main(){
Miracle::main();
return ;
} /*
Author: *Miracle*
*/

PS:

以后解一个多元一次不定方程,最小的数不太大的时候,同余最短路都可以尝试!

CF986F Oppa Funcan Style Remastered的更多相关文章

  1. [CF986F]Oppa Funcan Style Remastered[exgcd+同余最短路]

    题意 给你 \(n\) 和 \(k\) ,问能否用 \(k\) 的所有 \(>1\) 的因子凑出 \(n\) .多组数据,但保证不同的 \(k\) 不超过 50 个. \(n\leq 10^{1 ...

  2. 「CF986F」 Oppa Funcan Style Remastered

    「CF986F」 Oppa Funcan Style Remastered Link 首先发现分解成若干个 \(k\) 的因数很蠢,事实上每个因数都是由某个质因子的若干倍组成的,所以可以将问题转换为分 ...

  3. codeforces986F Oppa Funcan Style Remastered【线性筛+最短路】

    容易看出是用质因数凑n 首先01个因数的情况可以特判,2个的情况就是ap1+bp2=n,b=n/p2(mod p1),这里的b是最小的特解,求出来看bp2<=n则有解,否则无解 然后剩下的情况最 ...

  4. [Codeforces 485F] Oppa Funcan Style Remastered

    [题目链接] https://codeforces.com/contest/986/problem/F [算法] 不难发现 , 每个人都在且仅在一个简单环中 , 设这些环长的长度分别为 A1, A2 ...

  5. Codeforces 986F - Oppa Funcan Style Remastered(同余最短路)

    Codeforces 题面传送门 & 洛谷题面传送门 感谢此题教会我一个东西叫做同余最短路(大雾 首先这个不同 \(k\) 的个数 \(\le 50\) 这个条件显然是让我们对每个 \(k\) ...

  6. 一句话题解&&总结

    CF79D Password: 差分.两点取反,本质是匹配!最短路+状压DP 取反是套路,匹配是发现可以把操作进行目的化和阶段化,从而第二次转化问题. 且匹配不会影响别的位置答案 sequence 计 ...

  7. The Air Jordan 4 Oreo Remastered would be re-released in 2015

    May be the Jordan 4 Oreo probably the most anticipated pair among the remastered Jordans for 2015? W ...

  8. JavaScript特性(attribute)、属性(property)和样式(style)

    最近在研读一本巨著<JavaScript忍者秘籍>,里面有一篇文章提到了这3个概念. 书中的源码可以在此下载.我将源码放到了线上,如果不想下载,可以直接访问在线网址,修改页面名就能访问到相 ...

  9. obj.style.z-index的正确写法

    obj.style.z-index的正确写法 今天发现obj.style.z-index在js里面报错,后来才知道在js里应该把含"-"的字符写成驼峰式,例如obj.style.z ...

随机推荐

  1. WebBrowser修改默认白色背景

      背景:在使用Winform的WebBrowser显示网页的时候,在网页还未加载完成之前会显示白色,刚好网页内容呈现黑色,这样视觉效果上就十分差,想把这层白色的去掉. 试了很久之后发现根本去不掉,应 ...

  2. ckfinder提示从服务器读取XML数据出错

    在web.xml中加入以下配置,具体路径根据工程配置写 <!-- ckfinder --> <servlet> <servlet-name>ConnectorSer ...

  3. python自动化---各类发送邮件方法及其可能的错误

    一.发送文本邮件 可能的问题1.:需要注意,目前QQ邮箱来讲,不能收到完整的邮件,即有些内容不能显示,最好全部使用网易邮箱: 可能的问题2.:在以往的文本邮件发送中,只写了 msg = MIMETex ...

  4. easyui combobox下拉框中显示大于号小于号的问题

    前两天同事做了个功能,通过勾选下拉框里的值进行列表查询,结果下拉框里的值是“0<t<=2”.“2<t<=5”.“t>5”这样的. combobox是用脚本渲染出来的,里面 ...

  5. Angular.js的自定义功能

    1,自定义指令,在html中输入标签显示想要的指令 html script部分 2,标签中的属性的 有属性值时可以通过函数的参数返回属性值 没有属性值时可以设置属性值(自定义属性值) html部分   ...

  6. 洛谷P1508 Likecloud-吃、吃、吃 [2017年4月计划 动态规划10]

    P1508 Likecloud-吃.吃.吃 题目背景 问世间,青春期为何物? 答曰:“甲亢,甲亢,再甲亢:挨饿,挨饿,再挨饿!” 题目描述 正处在某一特定时期之中的李大水牛由于消化系统比较发达,最近一 ...

  7. php中 重载的方法

    php中 重载(一)这个文章,谢谢.作为初学者,大牛勿喷: 基本是两个方法 __call,当调用对一个不可访问的对象方法时,会自动执行该魔术方法!(对象调用) 典型的两种处理方式: 1,给出友好的提示 ...

  8. vue里调用moment.js

    1.首先安装moment npm install moment --save 2.在main.js里引入 import moment from 'moment'//导入文件      Vue.prot ...

  9. LINUX下C++编程如何获得某进程的ID

    #include <stdio.h> #include <stdlib.h> #include <unistd.h> using namespace std; pi ...

  10. toString方法和valueof()方法的区别

    JavaScript引用类型之Array数组的toString()和valueof()方法的区别   一.转换方法 1.在JavaScript中几乎所有对象都具有toLocaleString().to ...