結果
問題 | No.1843 Tree ANDistance |
ユーザー | boatmuscles |
提出日時 | 2022-02-18 21:48:14 |
言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 315 ms / 2,000 ms |
コード長 | 806 bytes |
コンパイル時間 | 677 ms |
コンパイル使用メモリ | 66,444 KB |
最終ジャッジ日時 | 2025-01-27 23:54:35 |
ジャッジサーバーID (参考情報) |
judge3 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 38 |
コンパイルメッセージ
main.cpp: In function ‘int main()’: main.cpp:9:10: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result] 9 | scanf("%d", &N); | ~~~~~^~~~~~~~~~ main.cpp:12:14: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result] 12 | scanf("%d %d %d", A + i, B + i, C + i); | ~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
ソースコード
#include<cstdio> #include<atcoder/dsu> #include<atcoder/modint> using namespace atcoder; using Mint = modint1000000007; int main(){ int N; scanf("%d", &N); int A[N], B[N], C[N]; for(int i = 0; i < N-1; ++i){ scanf("%d %d %d", A + i, B + i, C + i); A[i]--,B[i]--; } Mint answer = Mint::raw(0); for (int bit = 0; bit < 30; bit++) { dsu uft(N); for (int i = 0; i < N-1; i++) if(C[i]>>bit&1) uft.merge(A[i], B[i]); auto result = uft.groups(); Mint reachable_pair = Mint::raw(0); for(auto &i : result) reachable_pair += Mint::raw(i.size())*Mint::raw(i.size()-1); answer += bit ? reachable_pair*Mint::raw(1<<(bit-1)) : reachable_pair/Mint::raw(2); } printf("%u\n", answer.val()); return 0; }