結果

問題 No.1843 Tree ANDistance
ユーザー boatmusclesboatmuscles
提出日時 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);
      |         ~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

ソースコード

diff #

#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;
}
0