제출 #990709

#제출 시각아이디문제언어결과실행 시간메모리
990709vjudge1Torrent (COI16_torrent)C++17
31 / 100
5 ms856 KiB
#include <bits/stdc++.h> using namespace std; #define ll long long int const N=1e3+5; int const mod=1e9+7; set<int> adj[N]; vector<int> path,ab; int n,a,b; int dp[N]; void dfs_dp(int node,int par){ vector<int> v; for(auto i:adj[node]){ if(i!=par){ dfs_dp(i,node); v.push_back(dp[i]); } } sort(v.begin(), v.end()); reverse(v.begin(), v.end()); for(int i=0;i<v.size();i++) dp[node]=max(dp[node],v[i]+i+1); } void dfs(int node,int par){ path.push_back(node); if(node==b) ab=path; for(auto i:adj[node]) if(i!=par) dfs(i,node); path.pop_back(); } int main(){ cin>>n>>a>>b; for(int i=0;i<n-1;i++){ int u,v; cin>>u>>v; adj[u].insert(v); adj[v].insert(u); } dfs(a,0); int ans=10000; for(int i=1;i<ab.size();i++){ //erase edge int u=ab[i-1],v=ab[i]; adj[u].erase(v); adj[v].erase(u); for(int i=0;i<=n;i++) dp[i]=0; dfs_dp(a,0); dfs_dp(b,0); ans=min(ans,max(dp[a],dp[b])); adj[u].insert(v); adj[v].insert(u); } cout<<ans<<endl; return 0; }

컴파일 시 표준 에러 (stderr) 메시지

torrent.cpp: In function 'void dfs_dp(int, int)':
torrent.cpp:22:15: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   22 |  for(int i=0;i<v.size();i++)
      |              ~^~~~~~~~~
torrent.cpp: In function 'int main()':
torrent.cpp:44:15: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   44 |  for(int i=1;i<ab.size();i++){
      |              ~^~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...