結果
| 問題 |
No.703 ゴミ拾い Easy
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2018-06-30 17:34:50 |
| 言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
| 結果 |
AC
|
| 実行時間 | 24 ms / 1,500 ms |
| コード長 | 1,733 bytes |
| コンパイル時間 | 2,098 ms |
| コンパイル使用メモリ | 169,152 KB |
| 実行使用メモリ | 10,240 KB |
| 最終ジャッジ日時 | 2025-01-02 13:56:40 |
| 合計ジャッジ時間 | 4,308 ms |
|
ジャッジサーバーID (参考情報) |
judge1 / judge3 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 4 |
| other | AC * 46 |
ソースコード
#include <bits/stdc++.h>
#pragma GCC optimize("O3")
#pragma GCC target("avx")
#define rep(i,n) for(int i = 0; i < (int)(n); i++)
#define ll long long
#define fi first
#define se second
#define push_back pb
#define show(x) cout << #x << " = " << x << "\n"
using namespace std;
typedef pair<int,int> P;
#define T long long
#define getchar getchar_unlocked
inline int in() {
int n, c;
while ((c = getchar()) < '0') if (c == EOF) return -1;
n = c - '0';
while ((c = getchar()) >= '0') n = n * 10 + c - '0';
return n;
}
class CHT
{
private:
using ptt = pair<T, T>;
bool check(ptt l1, ptt l2, ptt l3){
return (l2.first-l1.first)*(l3.second-l2.second)>=(l2.second-l1.second)*(l3.first-l2.first);
}
T f(int i, T x){
return lines[i].first * x + lines[i].second;
}
public:
vector<ptt> lines;
CHT(){};
void add(T a, T b){
ptt line(a, b);
while((int)lines.size() >= 2 && check(*(lines.end()-2), lines.back(), line)){
lines.pop_back();
}
lines.emplace_back(line);
}
T get(T x){
static int head = 0;
while((int)lines.size() - head >= 2 && f(head, x) > f(head + 1, x)){
head++;
}
return f(head, x);
}
};
int main()
{
int n = in();
vector<ll> a(n),x(n),y(n);
rep(i,n){
a[i] = in();
}
rep(i,n){
x[i] = in();
}
rep(i,n){
y[i] = in();
}
CHT cht;
cht.add(-2*x[0],x[0]*x[0]+y[0]*y[0]);
rep(i,n){
if(i < n-1){
cht.add(-2*x[i+1],cht.get(a[i])+x[i+1]*x[i+1]+y[i+1]*y[i+1]+a[i]*a[i]);
}else{
cout << cht.get(a[i])+a[i]*a[i] << "\n";
return 0;
}
}
}
;