제출 #99987

#제출 시각아이디문제언어결과실행 시간메모리
99987dantoh000Roller Coaster Railroad (IOI16_railroad)C++14
컴파일 에러
0 ms0 KiB
#include "railroad.h" #include <bits/stdc++.h> #define INF 1e18; using namespace std; int n; vector<int> s, t; long long memo[17][65537]; long long dp(int id, int mask){ //printf("%lld %lld\n",id,mask); if (mask == (1<<n) - 1) return 0; if (memo[id][mask] != -1) return memo[id][mask]; memo[id][mask] = INF; for (int i = 0; i < n; i++){ if (!(mask&(1<<i))){ memo[id][mask] = min(memo[id][mask],dp(i,(mask|(1<<i)))+max(0,t[id]-s[i])); } } return memo[id][mask]; } long long plan_roller_coaster(vector<int> t1, vector<int> t2) { n = (int) t1.size(); for (int i = 0; i < n; i++){ s.push_back(t1[i]); t.push_back(t2[i]); } long long ans = INF; if (n <= 16){ memset(memo,-1,sizeof(memo)); for (int i = 0; i < n; i++){ ans = min(ans,dp(i,1<<i)); } } else{ sort(s.begin(),s.end(),greater<int>()); sort(t.begin(),t.end(),greater<int>()); for (int i = 0; i < n; i++){ if (s[i] < t[i]) return 1; } return 0; } return ans; } main() { int n; assert(1 == scanf("%d", &n)); std::vector<int> s(n), t(n); for (int i = 0; i < n; ++i) assert(2 == scanf("%d%d", &s[i], &t[i])); long long ans = plan_roller_coaster(s, t); printf("%lld\n", ans); return 0; }

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

railroad.cpp:45:6: warning: ISO C++ forbids declaration of 'main' with no type [-Wreturn-type]
 main() {
      ^
/tmp/ccopfIl4.o: In function `main':
grader.cpp:(.text.startup+0x0): multiple definition of `main'
/tmp/cczyPaNx.o:railroad.cpp:(.text.startup+0x0): first defined here
collect2: error: ld returned 1 exit status