제출 #416145

#제출 시각아이디문제언어결과실행 시간메모리
416145DEQKDreaming (IOI13_dreaming)C++17
컴파일 에러
0 ms0 KiB
#include "dreaming.h" #include <bits/stdc++.h> #define ll long long #define int ll using namespace std; const int N = 100100; int ans; int us[N], dp[N], was[N]; vector<pair<int, int>> g[N]; pair<int, int> best; void dfs(int u) { us[u] = 1; for(auto to : g[u]) if(!us[to.first]) { dfs(to.first); dp[u] = max(dp[u], dp[to.first] + to.second); } } void dfs2(int u,int val) { was[u] = 1; vector<int> p, s; ans = max(ans, max(dp[u], val)); if(best.first > max(dp[u], val)) { best = {max(dp[u], val), u}; } for(int i = 0; i < g[u].size(); ++i) { int to = g[u][i].first, c = g[u][i].second; if(was[to]) continue; p.push_back(!p.empty() ? max(p.back(), dp[to] + c) : dp[to] + c); } for(int i = g[u].size() - 1; i >= 0; i--) { int to = g[u][i].first, c = g[u][i].second; if(was[to]) continue; s.push_back(s.empty() ? dp[to] + c : max(s.back(), dp[to] + c)); } reverse(s.begin(), s.end()); int q = -1; for(int i = 0; i < g[u].size(); i++) { int to = g[u][i].first, c = g[u][i].second; if(was[to]) continue; int f = val; ++q; if(q) f = max(f, p[q - 1]); if(q + 1 < s.size()) f = max(f, s[q + 1]); dfs2(to, f + c); } } int travelTime(int n,int m,int l,int a[],int b[],int t[]) { for(int i = 0; i < m; ++i) { int u = a[i],v = b[i],w = t[i]; g[u].push_back({v, w}); g[v].push_back({u, w}); } vector<pair<int, int>> d; for(int i = 0; i < n; ++i) { if(!us[i]) { dfs(i); best = {2e9, 0}; dfs2(i, 0); d.push_back(best); } } sort(d.begin(), d.end(), [&] (pair<int, int> &x, pair<int, int> &y) { return x.first > y.first; }); if(d.size() > 1) { ans = max(ans, d[0].first + d[1].first + l); } if(d.size() > 2) { ans = max(ans, d[1].first + d[2].first + 2 * l); } return ans; }

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

dreaming.cpp: In function 'void dfs2(long long int, long long int)':
dreaming.cpp:26:19: warning: comparison of integer expressions of different signedness: 'long long int' and 'std::vector<std::pair<long long int, long long int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   26 |  for(int i = 0; i < g[u].size(); ++i) {
      |                 ~~^~~~~~~~~~~~~
dreaming.cpp:38:19: warning: comparison of integer expressions of different signedness: 'long long int' and 'std::vector<std::pair<long long int, long long int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   38 |  for(int i = 0; i < g[u].size(); i++) {
      |                 ~~^~~~~~~~~~~~~
dreaming.cpp:44:12: warning: comparison of integer expressions of different signedness: 'long long int' and 'std::vector<long long int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   44 |   if(q + 1 < s.size()) f = max(f, s[q + 1]);
      |      ~~~~~~^~~~~~~~~~
/usr/bin/ld: /tmp/ccqVtZtf.o: in function `main':
grader.c:(.text.startup+0xd1): undefined reference to `travelTime'
collect2: error: ld returned 1 exit status