結果

問題 No.1054 Union add query
ユーザー mugen_1337mugen_1337
提出日時 2020-05-16 13:34:34
言語 C++17
(gcc 12.3.0 + boost 1.83.0)
結果
AC  
実行時間 560 ms / 2,000 ms
コード長 1,486 bytes
コンパイル時間 2,922 ms
コンパイル使用メモリ 208,092 KB
実行使用メモリ 41,176 KB
最終ジャッジ日時 2023-10-22 05:52:12
合計ジャッジ時間 6,513 ms
ジャッジサーバーID
(参考情報)
judge14 / judge11
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 2 ms
4,348 KB
testcase_01 AC 2 ms
4,348 KB
testcase_02 AC 2 ms
4,348 KB
testcase_03 AC 405 ms
11,792 KB
testcase_04 AC 560 ms
41,176 KB
testcase_05 AC 350 ms
7,688 KB
testcase_06 AC 341 ms
19,160 KB
testcase_07 AC 318 ms
19,160 KB
testcase_08 AC 250 ms
19,160 KB
testcase_09 AC 560 ms
40,324 KB
testcase_10 AC 139 ms
40,324 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

#include<bits/stdc++.h>
using namespace std;
#define ALL(x) x.begin(),x.end()
#define rep(i,n) for(int i=0;i<(n);i++)
#define debug(v) cout<<#v<<":";for(auto x:v){cout<<x<<' ';}cout<<endl;
#define INF 1000000000
#define mod 1000000007
using ll=long long;
const ll LINF=1001002003004005006ll;
int dx[]={1,0,-1,0};
int dy[]={0,1,0,-1};
// ll gcd(ll a,ll b){return b?gcd(b,a%b):a;}
template<class T>bool chmax(T &a,const T &b){if(a<b){a=b;return true;}return false;}
template<class T>bool chmin(T &a,const T &b){if(b<a){a=b;return true;}return false;}

signed main(){
    cin.tie(0);
    ios::sync_with_stdio(0);
    
    int n,q;cin>>n>>q;
    vector<ll> rootadd(n,0),nodeadd(n,0);
    vector<int> root(n);
    iota(ALL(root),0);
    vector<vector<int>> v(n);
    rep(i,n) v[i].push_back(i);
    while(q--){
        int t,a,b;cin>>t>>a>>b;a--;
        if(t==1){
            // unite a<-b
            b--;
            if(root[a]==root[b]) continue;
            if(v[root[a]].size()<v[root[b]].size()) swap(a,b);
            ll dif=rootadd[root[b]]-rootadd[root[a]];
            int rb=root[b];
            for(auto x:v[rb]){
                nodeadd[x]+=dif;
                root[x]=root[a];
                v[root[a]].push_back(x);
            }
            v[rb].clear();
        }
        else if(t==2){
            // add
            rootadd[root[a]]+=b;
        }
        else{
            // answer
            cout<<rootadd[root[a]]+nodeadd[a]<<endl;
        }
    }
    return 0;
}
0