結果
問題 | No.1488 Max Score of the Tree |
ユーザー | Nzt3 |
提出日時 | 2021-04-24 17:38:55 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 18 ms / 2,000 ms |
コード長 | 1,061 bytes |
コンパイル時間 | 2,054 ms |
コンパイル使用メモリ | 184,324 KB |
実行使用メモリ | 6,944 KB |
最終ジャッジ日時 | 2024-07-04 09:09:25 |
合計ジャッジ時間 | 3,347 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge4 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 16 ms
6,816 KB |
testcase_01 | AC | 17 ms
6,940 KB |
testcase_02 | AC | 17 ms
6,940 KB |
testcase_03 | AC | 18 ms
6,944 KB |
testcase_04 | AC | 18 ms
6,944 KB |
testcase_05 | AC | 2 ms
6,944 KB |
testcase_06 | AC | 6 ms
6,940 KB |
testcase_07 | AC | 10 ms
6,940 KB |
testcase_08 | AC | 8 ms
6,940 KB |
testcase_09 | AC | 7 ms
6,940 KB |
testcase_10 | AC | 11 ms
6,944 KB |
testcase_11 | AC | 17 ms
6,944 KB |
testcase_12 | AC | 2 ms
6,940 KB |
testcase_13 | AC | 5 ms
6,940 KB |
testcase_14 | AC | 9 ms
6,940 KB |
testcase_15 | AC | 7 ms
6,940 KB |
testcase_16 | AC | 3 ms
6,940 KB |
testcase_17 | AC | 5 ms
6,940 KB |
testcase_18 | AC | 13 ms
6,944 KB |
testcase_19 | AC | 8 ms
6,940 KB |
testcase_20 | AC | 4 ms
6,944 KB |
testcase_21 | AC | 3 ms
6,944 KB |
testcase_22 | AC | 7 ms
6,944 KB |
testcase_23 | AC | 2 ms
6,944 KB |
testcase_24 | AC | 2 ms
6,940 KB |
testcase_25 | AC | 2 ms
6,940 KB |
testcase_26 | AC | 6 ms
6,940 KB |
testcase_27 | AC | 3 ms
6,940 KB |
testcase_28 | AC | 3 ms
6,944 KB |
testcase_29 | AC | 5 ms
6,940 KB |
testcase_30 | AC | 14 ms
6,940 KB |
testcase_31 | AC | 18 ms
6,940 KB |
ソースコード
#include<bits/stdc++.h> using namespace std; const int mod=1e9+7; int main(){ int N,K; cin>>N>>K; vector<vector<pair<int,int>>>g(N); for(int i=0,a,b,c;i<N-1;i++){ cin>>a>>b>>c; a--,b--; g[a].push_back({b,c}); g[b].push_back({a,c}); } queue<int>bfs; vector<tuple<int,int,int>>ki(N); bfs.push(0); vector<int>dist(N,1e9),leaf; dist[0]=0; while(bfs.size()){ int t=bfs.front(); bfs.pop(); bool ha=true; for(auto i:g[t]){ if(dist[i.first]>dist[t]+i.second){ dist[i.first]=dist[t]+i.second; ki[i.first]={t,i.second,0}; ha=false; bfs.push(i.first); } } if(ha)leaf.push_back(t); } for(int i:leaf){ int t=i; while(t!=0){ get<2>(ki[t])++; t=get<0>(ki[t]); } } vector<int>dp(K+1); for(int i=1;i<N;i++){ for(int j=K;j>=0;j--){ if(get<1>(ki[i])<=j){ dp[j]=max(dp[j],dp[j-get<1>(ki[i])]+get<1>(ki[i])*get<2>(ki[i])); } } } int ans=dp.back(); for(int i:leaf){ ans+=dist[i]; } cout<<ans<<'\n'; }