結果
| 問題 |
No.1451 集団登校
|
| コンテスト | |
| ユーザー |
Nachia
|
| 提出日時 | 2021-03-31 15:12:01 |
| 言語 | C++17(gcc12) (gcc 12.3.0 + boost 1.87.0) |
| 結果 |
TLE
|
| 実行時間 | - |
| コード長 | 1,182 bytes |
| コンパイル時間 | 10,786 ms |
| コンパイル使用メモリ | 261,592 KB |
| 最終ジャッジ日時 | 2025-01-20 01:48:23 |
|
ジャッジサーバーID (参考情報) |
judge2 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 12 TLE * 6 MLE * 9 |
ソースコード
#include <bits/stdc++.h>
using namespace std;
using ll=long long;
using ull=unsigned long long;
#define rep(i,n) for(int i=0; i<(n); i++)
const ull M = 1000000007;
const ull inv2 = M/2+1;
struct DSU{
vector<int> V;
vector<int> Z;
vector<ull> P;
vector<ull> iP;
DSU(int n=0){
V.assign(n,-1);
Z.assign(n,1);
P.assign(n,1);
iP.assign(n,1);
}
pair<int,ull> leader(int a){
if(V[a]>=0){
auto r=leader(V[a]);
V[a]=r.first;
P[a]=P[a]*r.second%M;
return {V[a],P[a]};
}
return {a,1};
}
ull value(int a){
auto ap = leader(a);
return ap.second * P[ap.first] % M;
}
void merge(int u,int v){
auto up = leader(u); u=up.first;
auto vp = leader(v); v=vp.first;
if(Z[u]<Z[v]) swap(u,v);
if(Z[u]>Z[v]){
P[v]=0; iP[v]=0;
V[v]=u; Z[u]+=Z[v];
}
else{
P[v]=P[v]*iP[u]%M; iP[v]=iP[v]*P[u]%M;
P[u]=P[u]*inv2%M; iP[u]=iP[u]*2%M;
V[v]=u; Z[u]+=Z[v];
}
}
};
int N,Q;
DSU dsu;
int main(){
scanf("%d%d",&N,&Q);
dsu = DSU(N);
rep(i,Q){
int u,v; scanf("%d%d",&u,&v); u--; v--;
dsu.merge(u,v);
}
rep(i,N) printf("%llu\n",dsu.value(i));
return 0;
}
Nachia