結果
| 問題 |
No.1843 Tree ANDistance
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 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;
}