比赛 2026.5.16 评测结果 AAAAAAAAAAAAAAEEEEEE
题目名称 不是一道路径查询问题 最终得分 70
用户昵称 李金泽 运行时间 2.398 s
代码语言 C++ 内存使用 8.81 MiB
提交时间 2026-05-16 08:44:55
显示代码纯文本
#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<algorithm>
#define N 100005
#define M 500005
#define int long long
#define fo(i,l,r) for(int i=l;i<=r;i++)
#define rf(i,r,l) for(int i=r;i>=l;i--)
using namespace std;
int n,m,q,V,d,op,f[N],x,y,z;
bool ans[N];
struct edge{int u,v,w;}e[M];
struct question{int u;int v;}qu[M];
int fd(int x){return x^f[x]?f[x]=fd(f[x]):x;}
void mg(int x,int y){f[fd(x)]=fd(y);} 
int fp(int a,int n,int mod){
    int ans=1;
    while(n){
        if(n&1)ans=ans*a%mod;
        a=a*a%mod;
        n>>=1;
    }
    return ans;
}
int gcd(int a,int b){return b?gcd(b,a%b):a;}
int read(){
    int sum=0;bool f=0;char c=getchar();
    for(;c<48||c>57;c=getchar())if(c==45)f=1;
    for(;c>=48&&c<=57;c=getchar())sum=sum*10+(c&15);
    return f?-sum:sum;
}
signed main(){
    freopen("Paths.in","r",stdin);freopen("Paths.out","w",stdout);
    ios::sync_with_stdio(0);
    cin.tie(0);
    n=read();m=read();q=read();V=read();
    fo(i,1,m)e[i]={read(),read(),read()};
    fo(i,1,q)qu[i]={read(),read()};
    for(int i=60,s=0;~i;i--){
        s|=1ll<<i;
        if(s<V)continue;
        fo(j,1,n)f[j]=j;
        fo(j,1,m)
            if((e[j].w&s)==s)
                mg(e[j].u,e[j].v);
        fo(j,1,q)
            if(fd(qu[j].u)==fd(qu[j].v))
                ans[j]=1;
        s^=1ll<<i;
    }
    fo(i,1,q)printf("%s\n",ans[i]?"Yes":"No"); 
    return 0;
}