Submission #661476

#TimeUsernameProblemLanguageResultExecution timeMemory
661476LoboRoads (CEOI20_roads)C++17
15 / 100
102 ms6772 KiB
#include<bits/stdc++.h> using namespace std; const long long inf = (long long) 1e18 + 10; const int inf1 = (int) 1e9 + 10; #define int long long #define dbl long double #define endl '\n' #define sc second #define fr first #define mp make_pair #define pb push_back #define all(x) x.begin(), x.end() const int maxn = 1e6+10; int n, x[maxn], y[maxn]; pair<int,int> val[maxn]; dbl findy(int i, int xcur) { if(x[i] == x[i+1]) return y[i]; return ((dbl) y[i+1]-y[i])/((dbl) x[i+1]-x[i])*((dbl) xcur-x[i]) + y[i]; } void solve() { cin >> n; vector<pair<pair<int,int>,pair<int,int>>> pts; for(int i = 1; i <= 2*n; i+=2) { cin >> x[i] >> y[i]; cin >> x[i+1] >> y[i+1]; if(mp(x[i],y[i]) > mp(x[i+1],y[i+1])) { swap(x[i],x[i+1]); swap(y[i],y[i+1]); } pts.pb(mp(mp(x[i],y[i]),mp(i,1))); pts.pb(mp(mp(x[i+1],y[i+1]),mp(i,-1))); } sort(all(pts)); x[2*n+1] = -inf1; x[2*n+2] = inf1; y[2*n+1] = -inf1; y[2*n+2] = -inf1; val[2*n+1] = mp(-inf1,-inf1); vector<int> vec; vec.pb(2*n+1); for(auto X : pts) { if(X.sc.sc == 1) { int i = X.sc.fr; int xcur = X.fr.fr; int id = 0; // vec[id] is the last one under i for(int j = 0; j < vec.size(); j++) { if(findy(vec[j],xcur) > y[i]) { id = j-1; break; } } // cout << i << " " << id << endl; if(val[vec[id]].fr != -inf1) { cout << x[i] << " " << y[i] << " " << val[vec[id]].fr << " " << val[vec[id]].sc << endl; } val[vec[id]] = mp(x[i],y[i]); val[i] = mp(x[i],y[i]); vector<int> newvec; for(int j = 0; j <= id; j++) { newvec.pb(vec[j]); } newvec.pb(i); for(int j = id+1; j < vec.size(); j++) { newvec.pb(vec[j]); } swap(vec,newvec); } else { int i = X.sc.fr; int xcur = X.fr.fr; int id; for(int j = 0; j < vec.size(); j++) { if(vec[j] == i) { id = j; break; } } val[vec[id-1]] = mp(x[i+1],y[i+1]); vector<int> newvec; for(int j = 0; j < id; j++) { newvec.pb(vec[j]); } for(int j = id+1; j < vec.size(); j++) { newvec.pb(vec[j]); } swap(vec,newvec); } } } int32_t main() { ios::sync_with_stdio(false); cin.tie(0); // freopen("in.in", "r", stdin); // freopen("out.out", "w", stdout); int tt = 1; // cin >> tt; while(tt--) { solve(); } }

Compilation message (stderr)

roads.cpp: In function 'void solve()':
roads.cpp:54:30: 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]
   54 |             for(int j = 0; j < vec.size(); j++) {
      |                            ~~^~~~~~~~~~~~
roads.cpp:73:33: 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]
   73 |             for(int j = id+1; j < vec.size(); j++) {
      |                               ~~^~~~~~~~~~~~
roads.cpp:83:30: 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]
   83 |             for(int j = 0; j < vec.size(); j++) {
      |                            ~~^~~~~~~~~~~~
roads.cpp:96:33: 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]
   96 |             for(int j = id+1; j < vec.size(); j++) {
      |                               ~~^~~~~~~~~~~~
roads.cpp:80:17: warning: unused variable 'xcur' [-Wunused-variable]
   80 |             int xcur = X.fr.fr;
      |                 ^~~~
roads.cpp:93:30: warning: 'id' may be used uninitialized in this function [-Wmaybe-uninitialized]
   93 |             for(int j = 0; j < id; j++) {
      |                            ~~^~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...