이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
#include "overtaking.h"
using namespace std;
#define pb push_back
#define st first
#define nd second
typedef long long ll;
typedef long double ld;
const ll I = 1000'000'000'000'000'000LL;
const int II = 2'000'000'000;
const ll M = 1000'000'007LL;
const int N = 1'007;
int n, m, V;
ll dis[N], vel[N];
vector<pair<ll, int>> sta[N];
vector<ll> blo[N];
void DoSta()
{
for(int i = 1; i < m; ++i)
{
sort(sta[i].begin(), sta[i].end());
ll curma = 0LL, am = 0LL;
for(int j = 0; j < m; ++j)
{
ll na = sta[i][j].st + (dis[i + 1] - dis[i]) * vel[sta[i][j].nd];
na = max(na, curma);
sta[i + 1].pb(make_pair(na, sta[i][j].nd));
am = max(na, am);
if(j < m - 1 && sta[i][j].st != sta[i][j + 1].st)
curma = max(curma, am);
blo[i].pb(curma);
//cout << i << " Sta " << sta[i][j].nd << " " << sta[i][j].st << " " << na << "\n";
}
}
}
void init(int _L, int _N, vector<ll> _T, vector<int> _W, int _X, int _M, vector<int> _S)
{
n = _N; m = _N; V = _X;
for(int i = 1; i <= m; ++i)
dis[i] = _S[i - 1];
for(int i = 1; i <= n; ++i)
{
vel[i] = _W[i - 1];
sta[1].pb(make_pair(_T[i - 1], i));
}
DoSta();
}
long long arrival_time(ll _Y)
{
ll cur = _Y;
for(int i = 1; i < m; ++i)
{
int j = (lower_bound(sta[i].begin(), sta[i].end(), make_pair(cur, 0)) - sta[i].begin()) - 1;
ll nxt = cur + (dis[i + 1] - dis[i]) * V;
if(j >= 0)
nxt = max(nxt, blo[i][j]);
//cerr << i << " " << cur << " " << nxt << "\n";
cur = nxt;
}
return cur;
}
# | 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... |