Submission #9039132


Source Code Expand

 // ===================================
//   author: M_sea
//   website: http://m-sea-blog.com/
// ===================================
#include <algorithm>
#include <iostream>
#include <cstdlib>
#include <cstring>
#include <cstdio>
#include <cmath>
#define re register
using namespace std;

inline int read() {
    int X=0,w=1; char c=getchar();
    while (c<'0'||c>'9') { if (c=='-') w=-1; c=getchar(); }
    while (c>='0'&&c<='9') X=X*10+c-'0',c=getchar();
    return X*w;
}

const int N=100000+10;

int f[N],sz[N],sta[N],top=0;
inline int find(int x) { return x==f[x]?x:find(f[x]); }
inline void merge(int x,int y) {
    x=find(x),y=find(y);
    if (x==y) return;
    if (sz[x]>sz[y]) swap(x,y);
    f[x]=y,sz[y]+=sz[x],sta[++top]=x;
}
inline void undo(int pos) {
    while (top>pos) { int x=sta[top--]; sz[f[x]]-=sz[x],f[x]=x; }
}

int n,m,Q,ans[N];
struct edge { int u,v; } e[N];
struct query { int x,y,z,id; } q[N],lq[N],rq[N];

inline void solve(int l,int r,int ql,int qr) {
    if (ql>qr) {
        for (re int i=l;i<=r;++i) merge(e[i].u,e[i].v);
        return;
    }
    if (l==r) {
        for (re int i=ql;i<=qr;++i) ans[q[i].id]=l;
        merge(e[l].u,e[l].v);
        return;
    }
    int mid=(l+r)>>1,tmp=top,ls=0,rs=0;
    for (re int i=l;i<=mid;++i) merge(e[i].u,e[i].v);
    for (re int i=ql;i<=qr;++i) {
        int x=find(q[i].x),y=find(q[i].y);
        int s=x==y?sz[x]:sz[x]+sz[y];
        if (s>=q[i].z) lq[++ls]=q[i];
        else rq[++rs]=q[i];
    }
    undo(tmp);
    for (re int i=1;i<=ls;++i) q[ql+i-1]=lq[i];
    for (re int i=1;i<=rs;++i) q[ql+ls+i-1]=rq[i];
    solve(l,mid,ql,ql+ls-1),solve(mid+1,r,ql+ls,qr);
}

int main() {
    n=read(),m=read();
    for (re int i=1;i<=m;++i) e[i].u=read(),e[i].v=read();
    Q=read();
    for (re int i=1;i<=Q;++i)
        q[i].x=read(),q[i].y=read(),q[i].z=read(),q[i].id=i;
    for (re int i=1;i<=n;++i) f[i]=i,sz[i]=1;
    solve(1,m,1,Q);
    for (re int i=1;i<=Q;++i) printf("%d\n",ans[i]);
    return 0;
}

Submission Info

Submission Time
Task D - Stamp Rally
User M_sea
Language C++14 (GCC 5.4.1)
Score 1000
Code Size 2056 Byte
Status AC
Exec Time 122 ms
Memory 7808 KB

Judge Result

Set Name Sample All
Score / Max Score 0 / 0 1000 / 1000
Status
AC × 1
AC × 33
Set Name Test Cases
Sample 0_00.txt
All 0_00.txt, 1_00.txt, 1_01.txt, 1_02.txt, 1_03.txt, 1_04.txt, 1_05.txt, 1_06.txt, 1_07.txt, 1_08.txt, 1_09.txt, 1_10.txt, 1_11.txt, 1_12.txt, 1_13.txt, 1_14.txt, 1_15.txt, 1_16.txt, 1_17.txt, 1_18.txt, 1_19.txt, 1_20.txt, 1_21.txt, 1_22.txt, 1_23.txt, 1_24.txt, 1_25.txt, 1_26.txt, 1_27.txt, 1_28.txt, 1_29.txt, 1_30.txt, 1_31.txt
Case Name Status Exec Time Memory
0_00.txt AC 2 ms 4352 KB
1_00.txt AC 56 ms 7040 KB
1_01.txt AC 70 ms 7296 KB
1_02.txt AC 60 ms 7040 KB
1_03.txt AC 71 ms 7424 KB
1_04.txt AC 61 ms 7040 KB
1_05.txt AC 73 ms 7424 KB
1_06.txt AC 62 ms 7040 KB
1_07.txt AC 73 ms 7552 KB
1_08.txt AC 64 ms 7040 KB
1_09.txt AC 74 ms 7424 KB
1_10.txt AC 68 ms 7040 KB
1_11.txt AC 76 ms 7424 KB
1_12.txt AC 73 ms 7040 KB
1_13.txt AC 79 ms 7424 KB
1_14.txt AC 66 ms 7040 KB
1_15.txt AC 65 ms 7040 KB
1_16.txt AC 121 ms 7808 KB
1_17.txt AC 120 ms 7808 KB
1_18.txt AC 122 ms 7808 KB
1_19.txt AC 120 ms 7808 KB
1_20.txt AC 116 ms 7808 KB
1_21.txt AC 120 ms 7808 KB
1_22.txt AC 118 ms 7808 KB
1_23.txt AC 120 ms 7808 KB
1_24.txt AC 120 ms 7808 KB
1_25.txt AC 121 ms 7808 KB
1_26.txt AC 120 ms 7808 KB
1_27.txt AC 118 ms 7808 KB
1_28.txt AC 120 ms 7808 KB
1_29.txt AC 120 ms 7808 KB
1_30.txt AC 118 ms 7808 KB
1_31.txt AC 118 ms 7808 KB