제출 #935031

#제출 시각아이디문제언어결과실행 시간메모리
935031dimashhhAliens (IOI16_aliens)C++17
100 / 100
799 ms24552 KiB
#include <bits/stdc++.h> #include<aliens.h> using namespace std; const int N = 1e6 + 3, MOD = 1e9 + 7; typedef long long ll; int n,m,k; vector<pair<ll,ll>> a,x; ll res; ll dp[N],L[N],R[N]; int col[N]; struct line{ ll k,b; int id; ll calc(ll x){ return k * x + b; } }; vector<line> st; long double cross(line x,line y){ return (long double)(x.b - y.b) / (long double)(y.k - x.k); } void add(line nv){ int m = (int)st.size(); while(st.size() > 1 && cross(nv,st[m - 1]) <= cross(st[m - 1],st[m - 2])){ st.pop_back(); m--; } st.push_back(nv); } pair<int,ll> get(ll x){ int l = -1,r = (int)st.size() - 1; while(r - l > 1){ int mid = (l + r) >> 1; if(cross(st[mid],st[mid + 1]) > (long double)x){ r = mid; }else{ l = mid; } } ll mn = 1e18; int ret = 1e9; for(auto j:st){ if(j.calc(x) <= mn){ mn = j.calc(x); ret = j.id; } } // if(st[r].id != ret) { // cout << st[r].id << ' ' << ret << "x\n"; // cout << x << '\n'; // for(int i = 0;i < (int)st.size() - 1;i++){ // cout << cross(st[i],st[i + 1]) << ' '; // } // cout << '\n'; // for(auto j:st){ // cout << j.id << ' '; // } // cout << '\n'; // // exit(0); // } return {st[r].id,st[r].calc(x)}; } ll f(ll pen){ st.clear(); dp[0] = 0; col[0] = 0; for(int i = 1;i <= n;i++){ add({-L[i], dp[i - 1] + L[i] * L[i] - max(R[i - 1] - L[i], 0ll) * max(0ll, R[i - 1] - L[i]) + pen,i}); pair<int,ll> g = get(2 * R[i]); dp[i] = g.second + R[i] * R[i]; col[i] = col[g.first - 1] + 1; } res = dp[n]; return col[n]; } long long take_photos(int nn,int mm,int kk,vector<int> rr,vector<int> cc){ n = nn; m = mm; k = kk; for(int i = 1;i <= n;i++){ int l = rr[i - 1],r = cc[i - 1]; ++l;++r; if(l > r){ swap(l,r); } a.push_back({l,-r}); } sort(a.begin(),a.end()); int mx = 0; x.push_back({0,0}); for(auto [l,r]:a){ r = -r; if(r > mx){ mx = r; x.push_back({l,r}); } } sort(x.begin(),x.end()); n = (int)x.size() - 1; for (int i = 1; i <= n; i++) { L[i] = x[i].first - 1; R[i] = x[i].second; } ll l = -1,r = 1e15; k = min(k,n); while(r - l > 1) { ll mid = (l + r) >> 1; if (f(mid) >= k) { l = mid; } else { r = mid; } } ll x = f(l); return res - k * 1ll * l; }

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

aliens.cpp: In function 'std::pair<int, long long int> get(ll)':
aliens.cpp:44:9: warning: variable 'ret' set but not used [-Wunused-but-set-variable]
   44 |     int ret = 1e9;
      |         ^~~
aliens.cpp: In function 'long long int take_photos(int, int, int, std::vector<int>, std::vector<int>)':
aliens.cpp:118:8: warning: unused variable 'x' [-Wunused-variable]
  118 |     ll x = f(l);
      |        ^
#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...