이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <iostream>
#include <string>
#include <unordered_map>
#include <unordered_set>
#include <cstring>
#include <chrono>
#include <vector>
#include <map>
#include <random>
#include <set>
#include <algorithm>
#include <math.h>
#include <cstdio>
#include <stdio.h>
#include <queue>
#include <bitset>
#include <cstdlib>
#include <deque>
#include <cassert>
#include <stack>
using namespace std;
#define mp make_pair
#define f first
#define se second
#define pb push_back
#define ppb pop_back
#define ll long long
#define ull unsigned long long
#define cntbit(x) __builtin_popcount(x)
#define endl '\n'
#define uset unordered_set
#define umap unordered_map
#define all(x) x.begin(), x.end()
#define pii pair<int, int>
#define ld long double
#define pll pair<long long, long long>
const int mod = 1e9 + 7;
const ll inf = 2e15;
const int N = 1e5 + 15;
pair <ld, int> dp[N];
int l[N], r[N];
int ord[N];
vector <pii> tmp;
ll val[N];
inline ll sq(ll x) {
return x * x;
}
inline void Min(pair <ld, int> &a, pair <ld, int> b) {
a = min(a, b);
}
struct line {
int k;
ll b;
int t;
line(int k, ld b, int t) : k(k), b(b), t(t) { }
inline pair <ld, int> get(int x) {
return mp((ll)k * x + b, t + 1);
}
};
vector <line> hull;
int ptr;
inline bool bad(line a, line b, line c) {
if((a.b - c.b) * (c.k - b.k) >= (c.k - a.k) * (b.b - c.b))
return true;
if((a.b - c.b) * (c.k - b.k) == (c.k - a.k) * (b.b - c.b) && c.t < b.t)
return true;
return false;
}
inline void add(line nw) {
while(hull.size() > 1 && bad(hull[hull.size() - 2], hull.back(), nw))
hull.ppb();
hull.pb(nw);
}
inline pair <ld, int> get(int x) {
ptr = min(ptr, (int)hull.size() - 1);
while(ptr + 1 < hull.size() && hull[ptr].get(x) >= hull[ptr + 1].get(x))
++ptr;
return hull[ptr].get(x);
}
inline int check(ll C, int n) {
hull.clear();
ptr = 0;
for(int i = 1; i < N; ++i)
dp[i] = mp(inf, 0);
dp[0] = mp(0, 0);
for(int i = 1; i <= n; ++i) {
add(*new line(-2 * l[i], sq(l[i]) + dp[i-1].f - val[i], dp[i-1].se));
pair <ll, int> valnw = get(r[i] + 1);
valnw.f += sq(r[i] + 1) + C;
dp[i] = valnw;
}
return dp[n].se;
}
ll take_photos(int n, int m, int k, std::vector<int> row, std::vector<int> col) {
for(int i = 0; i < n; ++i) {
l[i+1] = min(row[i], col[i]) + 1;
r[i+1] = max(row[i], col[i]) + 1;
ord[i+1] = i+1;
}
sort(ord + 1, ord + 1 + n, [&](int x, int y) {
return mp(l[x], -r[x]) < mp(l[y], -r[y]);
});
for(int i = 1; i <= n; ++i)
if(tmp.empty() || !(tmp.back().f <= l[ord[i]] && tmp.back().se >= r[ord[i]]))
tmp.pb(mp(l[ord[i]], r[ord[i]]));
n = tmp.size();
for(int i = 1; i <= n; ++i) {
l[i] = tmp[i-1].f, r[i] = tmp[i-1].se;
val[i] = sq(max(0, r[i-1] - l[i] + 1));
}
ll l = 0, r = (ll)m * m, res = 0;
while(l <= r) {
ll mid = l + r >> 1;
int val = check(mid, n);
if(val <= k) {
r = mid - 1;
res = mid;
}
else
l = mid + 1;
}
check(res, n);
return (dp[n].f - res * dp[n].se);
}
컴파일 시 표준 에러 (stderr) 메시지
aliens.cpp: In function 'std::pair<long double, int> get(int)':
aliens.cpp:85:19: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
while(ptr + 1 < hull.size() && hull[ptr].get(x) >= hull[ptr + 1].get(x))
~~~~~~~~^~~~~~~~~~~~~
aliens.cpp: In function 'long long int take_photos(int, int, int, std::vector<int>, std::vector<int>)':
aliens.cpp:124:20: warning: suggest parentheses around '+' inside '>>' [-Wparentheses]
ll mid = l + r >> 1;
~~^~~
# | 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... |