結果

問題 No.2638 Initial fare
ユーザー 👑 ramdos
提出日時 2024-02-11 13:36:22
言語 C++17
(gcc 13.3.0 + boost 1.87.0)
結果
TLE  
実行時間 -
コード長 792 bytes
コンパイル時間 1,944 ms
コンパイル使用メモリ 197,920 KB
最終ジャッジ日時 2025-02-19 05:03:07
ジャッジサーバーID
(参考情報)
judge3 / judge4
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 1 TLE * 1 -- * 23
権限があれば一括ダウンロードができます

ソースコード

diff #

//N^2
#include <bits/stdc++.h>
using namespace std;
using ll = long long;
#define rep(i, n) for (int i = 0; i < (int)(n); i++)
int main(){
    ll N;
    cin >> N;
    vector<ll> v(N);
    vector<pair<ll,ll>> e(N-1);
    rep(i,N-1){
        cin >> e[i].first >> e[i].second;
        e[i].first--;
        e[i].second--;
        v[e[i].first]++;
        v[e[i].second]++;
    }
    ll ans = N-1; //distance=1
    rep(i,N){ //distance=2
        ans+=v[i]*(v[i]-1)/2;
    }
    rep(i,N-1){//distance=3
        ll s=-1;
        ll t=-1;
        rep(j,N-1){
            if(e[i].first==e[j].first) s++;
            if(e[i].first==e[j].second) s++;
            if(e[i].second==e[j].first) t++;
            if(e[i].second==e[j].second) t++;
        }
        ans+=s*t;
    }
    cout << ans << endl;
}
0