結果

問題 No.3309 Aging Railway
コンテスト
ユーザー yu23578
提出日時 2025-09-18 16:17:56
言語 C++17
(gcc 13.3.0 + boost 1.87.0)
結果
AC  
実行時間 596 ms / 3,000 ms
コード長 986 bytes
コンパイル時間 2,134 ms
コンパイル使用メモリ 209,284 KB
実行使用メモリ 38,784 KB
最終ジャッジ日時 2025-10-09 22:40:56
合計ジャッジ時間 11,048 ms
ジャッジサーバーID
(参考情報)
judge2 / judge3
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
other AC * 20
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <bits/stdc++.h>
using namespace std;

int N,M;
int INF = 1e9;

signed main(){
  cin>>N>>M;
  vector<vector<pair<int,int>>> G(N);
  for(int i = 0; i < N - 1; i++){
    int u,v; cin>>u>>v; u--;v--;
    G[u].push_back({v,i});
    G[v].push_back({u,i});
  }
  vector<vector<int>> dist(N,vector<int>(N,INF));
  queue<int> Q;
  for(int i = 0; i < N; i++){
    Q.push(i);
    vector<bool> visited(N);
    visited[i] = true;
    while(!Q.empty()){
      int now = Q.front();
      Q.pop();
      for(pair<int,int> j:G[now]){
        int nex = j.first;
        int yea = j.second;
        if(visited[nex]) continue;
        visited[nex] = true;
        dist[i][nex] = min(dist[i][now],yea);
        Q.push(nex);
      }
    }
  }
  vector<int> ans(N-1);
  ans[0] = M;
  for(int i = 0; i < M; i++){
    int s,t; cin>>s>>t; s--; t--;
    ans[dist[s][t]]--;
  }
  for(int i = 1; i < N-1; i++){
    ans[i] += ans[i-1];
  }
  for(int i = 0; i < N - 1; i++){
    cout << ans[i] << "\n";
  }
}
0