結果
問題 | No.1054 Union add query |
ユーザー | 山下 |
提出日時 | 2020-05-15 23:08:04 |
言語 | C++14 (gcc 12.3.0 + boost 1.83.0) |
結果 |
TLE
|
実行時間 | - |
コード長 | 1,217 bytes |
コンパイル時間 | 1,831 ms |
コンパイル使用メモリ | 174,592 KB |
実行使用メモリ | 18,080 KB |
最終ジャッジ日時 | 2024-09-19 13:08:14 |
合計ジャッジ時間 | 5,533 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge3 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 2 ms
10,624 KB |
testcase_01 | AC | 2 ms
5,376 KB |
testcase_02 | AC | 2 ms
5,376 KB |
testcase_03 | TLE | - |
testcase_04 | -- | - |
testcase_05 | -- | - |
testcase_06 | -- | - |
testcase_07 | -- | - |
testcase_08 | -- | - |
testcase_09 | -- | - |
testcase_10 | -- | - |
ソースコード
#include <bits/stdc++.h> using namespace std; typedef long long int ll; ll mod = 1000000007; ll r(ll x, ll y) { if (y == 0) return 1; else if (y % 2 == 0) return r(x, y/2) * r(x, y/2) % mod; else return x * r(x, (y-1)/2) % mod * r(x, (y-1)/2) % mod; } int main() { ll n, q; scanf("%lld%lld", &n, &q); vector<int> pa(n); for (int i = 0; i < n; i++) pa[i] = i; vector<vector<int>> oya(n, vector<int>(1)); for (int i = 0; i < n; i++) oya[i][0] = i; vector<ll> sum(n, 0); for (int i = 0; i < q; i++) { int t, a, b; scanf("%d%d%d", &t, &a, &b); if (t == 1) { a--; b--; int na = oya[pa[a]].size(); int nb = oya[pa[b]].size(); if (pa[a] != pa[b]) { int p; if (na >= nb) { p = pa[b]; for (int x : oya[pa[b]]) { pa[x] = pa[a]; oya[pa[a]].push_back(x); } } else { p = pa[a]; for (int x : oya[pa[a]]) { pa[x] = pa[b]; oya[pa[b]].push_back(x); } } } } else if (t == 2) { a--; for (int x : oya[pa[a]]) { sum[x] += b; } } else if (t == 3) { a--; printf("%lld\n", sum[a]); } } }