Submission #824888

#TimeUsernameProblemLanguageResultExecution timeMemory
824888vnm06Aliens (IOI16_aliens)C++14
4 / 100
1 ms212 KiB
#include "aliens.h" #include<bits/stdc++.h> using namespace std; struct line { long double res, cf, tm; int brp; line() {} line(long double a, long double b, long double c, int d) { res=a; cf=b; tm=c; brp=d; } }; int N; pair<int, int> pr[100005]; int id=0; long double T, ans, totbr; vector<line> lines; void add_line(int k) { long double res, br, tm, cf; if(lines.empty()) { res=(pr[k].second-pr[k].first+1)*(pr[k].second-pr[k].first+1)+T, br=1; } else { while(id!=lines.size()-1 && lines[id+1].tm<=pr[k].second) id++; res=lines[id].res+(pr[k].second-lines[id].cf+1)*(pr[k].second-lines[id].cf+1)+T; br=lines[id].brp+1; } if(k==N-1) { ans=res; totbr=br; } else { cf=pr[k+1].first; if(cf<=pr[k].second) res-=(pr[k].second-cf+1)*(pr[k].second-cf+1); int tN=lines.size(); while(tN>id) { long double vr=lines[tN-1].tm, res2=lines[tN-1].res, cf2=lines[tN-1].cf; if((vr-cf+1)*(vr-cf+1)+res<=(vr-cf2+1)*(vr-cf2+1)+res2) tN--; else break; } if(tN==id) lines.push_back(line(res, cf, 0, br)); else { long double vr=lines[tN-1].tm, res2=lines[tN-1].res, cf2=lines[tN-1].cf, tm; tm=(res+(cf-1)*(cf-1)-(cf2-1)*(cf2-1)-res2)/(2*cf-2*cf2); lines.push_back(line(res, cf, tm, br)); } } } pair<int, long double> solve() { id=0; lines.resize(0); lines.push_back(line(0, pr[0].first, 0, 0)); for(int i=0; i<N; i++) add_line(i); return {totbr, ans}; } long long take_photos(int n, int m, int k, std::vector<int> r, std::vector<int> c) { N=n; for(int i=0; i<n; i++) if(r[i]>c[i]) swap(r[i], c[i]); for(int i=0; i<n; i++) pr[i]={r[i], c[i]}; sort(pr, pr+N); int id=0; for(int i=1; i<N; i++) { if(pr[i].second<=pr[id].second) continue; if(pr[i].first!=pr[id].first) id++; swap(pr[id], pr[i]); } N=n=id+1; k=min(k, n); ///for(int i=0; i<n; i++) cout<<pr[i].first<<" "<<pr[i].second<<endl; long double le=0, ri=1e12; while(ri-le>1e-6) { long double mid=(le+ri)/2; T=mid; pair<int, long double> pr=solve(); ///cout<<T<<" "<<pr.second<<" "<<pr.first<<endl; if(pr.first==k) return pr.second-mid*k; else if(pr.first<k) ri=mid; else le=mid; } T=le; pair<int, long double> pr=solve(); return round(pr.second-T*k); }

Compilation message (stderr)

aliens.cpp: In function 'void add_line(int)':
aliens.cpp:35:17: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<line>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   35 |         while(id!=lines.size()-1 && lines[id+1].tm<=pr[k].second) id++;
      |               ~~^~~~~~~~~~~~~~~~
aliens.cpp:58:25: warning: unused variable 'vr' [-Wunused-variable]
   58 |             long double vr=lines[tN-1].tm, res2=lines[tN-1].res, cf2=lines[tN-1].cf, tm;
      |                         ^~
aliens.cpp:28:26: warning: unused variable 'tm' [-Wunused-variable]
   28 |     long double res, br, tm, cf;
      |                          ^~
#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...