제출 #270627

#제출 시각아이디문제언어결과실행 시간메모리
270627stoyan_malininRoller Coaster Railroad (IOI16_railroad)C++14
0 / 100
910 ms44244 KiB
#include "railroad.h" //#include "grader.cpp" #include <set> #include <map> #include <cstring> #include <iostream> #include <algorithm> using namespace std; const long long inf = 1e18 + 5; struct DSU { vector <int> parent; DSU(){} DSU(int n) { this->parent.resize(n+5); for(int i = 0;i<=n;i++) this->parent[i] = i; } int Find(int x) { if(parent[x]==x) return x; parent[x] = Find(parent[x]); return parent[x]; } bool Union(int u, int v) { u = Find(u); v = Find(v); if(u==v) return false; parent[v] = u; return true; } }; int n; vector <int> s, t; map <int, int> code; vector <int> invCode; void init() { set <int> nums; for(int x: s) nums.insert(x); for(int x: t) nums.insert(x); invCode.resize(nums.size()+5); for(int x: nums) { code[x] = code.size() - 1; invCode[ code[x] ] = x; //cout << x << " -> " << code[x] << '\n'; } for(int &x: s) x = code[x]; for(int &x: t) x = code[x]; } long long plan_roller_coaster(vector<int> _s, vector<int> _t) { _s.push_back(int(1e9+5)); _t.push_back(1); s = _s; t = _t; n = s.size(); init(); return 0; DSU T(code.size()); long long answer = 0; vector <int> start, finish; finish.assign(code.size()+5, 0); start.assign(code.size()+5, 0); //cout << '\n'; return answer; for(int i = 0;i<n;i++) { //cout << s[i] << " " << t[i] << '\n'; T.Union(s[i], t[i]); int x = s[i]; int y = t[i]; if(x>y) swap(x, y); start[x] += ((s[i]<t[i])?+1:-1); finish[y] += ((s[i]<t[i])?+1:-1); } int val = 0; for(int i = 0;i<code.size()-1;i++) { val += start[i]; val -= finish[i]; //cout << i << " => " << val << " || " << start[i] << " " << finish[i] << '\n'; if(val>0) { T.Union(i, i+1); answer += val*1LL*(invCode[i+1]-invCode[i]); } else if(val<0) { T.Union(i, i+1); } } vector <pair <long long, int>> edges; for(int i = 0;i<code.size()-1;i++) { if(T.Find(i)!=T.Find(i+1)) { //cout << " -> " << i << '\n'; edges.push_back({invCode[i+1]-invCode[i], i}); } } sort(edges.begin(), edges.end()); for(pair <long long, int> x: edges) { if(T.Union(x.second, x.second+1)==true) answer += x.first; } return answer; } /* 2 4 2 3 5 4 1 7 4 3 5 8 6 6 */

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

railroad.cpp: In function 'long long int plan_roller_coaster(std::vector<int>, std::vector<int>)':
railroad.cpp:106:20: warning: comparison of integer expressions of different signedness: 'int' and 'std::map<int, int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
  106 |     for(int i = 0;i<code.size()-1;i++)
      |                   ~^~~~~~~~~~~~~~
railroad.cpp:124:20: warning: comparison of integer expressions of different signedness: 'int' and 'std::map<int, int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
  124 |     for(int i = 0;i<code.size()-1;i++)
      |                   ~^~~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...