이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include "aliens.h"
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
struct segment{
int l, r;
segment(int _l, int _r){
l = _l;
r = _r;
}
};
struct line{
ll a, b;
int cnt;
line(ll _a = 0, ll _b = 0, int _cnt = 0){
a = _a;
b = _b;
cnt = _cnt;
}
};
struct convexHull{
vector <line> d;
int ptr;
void reset(){
d.clear();
ptr = 0;
}
ll calcY(const line &l, ll x){
return l.a * x + l.b;
}
bool bad(const line &l1, const line &l2, const line &l3){
return (l2.a - l3.a) * (l2.b - l1.b) >= (l1.a - l2.a) * (l3.b - l2.b);
}
void add(const line &newLine){
while (d.size() > 1){
if (bad(d[d.size() - 2], d[d.size() - 1], newLine))
d.pop_back();
else
break;
}
d.push_back(newLine);
}
ll getMin(ll x){
assert(!d.empty());
ptr = min(ptr, (int) d.size() - 1);
while (ptr < (int) d.size() - 1)
if (calcY(d[ptr], x) >= calcY(d[ptr + 1], x))
ptr++;
else
break;
return calcY(d[ptr], x);
}
int getCnt(ll x){
assert(!d.empty());
ptr = min(ptr, (int) d.size() - 1);
while (ptr < (int) d.size() - 1)
if (calcY(d[ptr], x) >= calcY(d[ptr + 1], x))
ptr++;
else
break;
return d[ptr].cnt;
}
} cvh;
int n, m, k;
vector <segment> segs;
vector <vector <ll> > dp;
void prepare(){
sort(segs.begin(), segs.end(), [](const segment &a, const segment &b){
if (a.l != b.l)
return a.l < b.l;
return a.r > b.r;
});
vector <segment> tmp;
int maxR = -1;
for(segment s : segs){
if (s.r > maxR)
tmp.push_back(s);
maxR = max(maxR, s.r);
}
segs = tmp;
n = segs.size();
}
ll cost(int l, int r){
assert(l <= r || l > 0);
int w = segs[r].r - segs[l].l + 1;
int intersect = max(0, segs[l - 1].r - segs[l].l + 1);
return (ll) w * w - (ll) intersect * intersect;
}
ll calc(ll c, bool value = 0){
cvh.reset();
cvh.add(line(-2 * segs[1].l, (ll) segs[1].l * segs[1].l, 0));
ll val, cnt;
for(int i = 1; i <= n; i++){
val = cvh.getMin(segs[i].r + 1) + (ll) (segs[i].r + 1) * (segs[i].r + 1) + c;
cnt = cvh.getCnt(segs[i].r + 1) + 1;
cvh.add(line(-2 * segs[i + 1].l, (ll) segs[i + 1].l * segs[i + 1].l + val
- (ll) max(0, segs[i].r - segs[i + 1].l + 1) * max(0, segs[i].r - segs[i + 1].l + 1), cnt));
}
if (value)
return val;
return cnt;
}
ll solve(){
segs.insert(segs.begin(), segment(-1, -1));
ll l = 0, r = 1e18, best = -1;
while (l <= r){
ll mid = (l + r) >> 1;
if (calc(mid) <= k){
best = mid;
r = mid - 1;
} else {
l = mid + 1;
}
}
return calc(best, 1) - best * calc(best) - (min((ll) k, calc(best - 1)) - calc(best)) * (best - 1);
}
ll take_photos(int _n, int _m, int _k, vector<int> r, vector<int> c){
n = _n;
m = _m;
k = _k;
for(int i = 0; i < n; i++)
segs.push_back(segment(min(r[i], c[i]), max(r[i], c[i])));
prepare();
return solve();
}
컴파일 시 표준 에러 (stderr) 메시지
aliens.cpp: In function 'll calc(ll, bool)':
aliens.cpp:102:13: warning: 'cnt' may be used uninitialized in this function [-Wmaybe-uninitialized]
102 | ll val, cnt;
| ^~~
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |