This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include "fish.h"
#include <bits/stdc++.h>
using namespace std;
using ll = long long;
#define MP make_pair
#define fi first
#define se second
#define pll pair <ll,ll>
#define sz(a) (ll((a).size()))
#define BIT(mask,i) (((mask) >> (i))&1LL)
#define MASK(i) (1LL<<(i))
ll n,m;
const ll MAXN = 1e5+100;
const ll INF = 1e18;
struct fish{
ll y,w,v0,v1;
bool operator < (const fish &p)const {
return y < p.y;
}
};
vector <fish> dp[MAXN];
long long max_weights(int N, int M, std::vector<int> X, std::vector<int> Y,
std::vector<int> W) {
n=N,m=M;
for (ll i = 0;i < m;i ++){
dp[X[i]+1].push_back({Y[i],W[i],0,0});
}
for (ll i = 0;i <= n+1;i ++){
dp[i].push_back({-1,0,0,0});
sort(dp[i].begin(),dp[i].end());
if (dp[i].back().y != n - 1)dp[i].push_back({n-1,0,0,0});
}
for (ll i = 2;i <= n;i ++){
// cout<<"COL "<<i<<endl;
dp[i-2][0].v1 = dp[i-1][0].v0;
ll ptr = 0;
ll max1 = -INF;
ll sum = 0;
for (auto &x:dp[i-1]){
while (dp[i-2][ptr].y < x.y){
max1 = max(max1,dp[i-2][ptr].v1 - sum);
ptr++;
}
sum += x.w;
x.v1 = max1 + sum;
// cout<<"V1 "<<x.y<<' '<<x.v1<<'\n';
}
dp[i].back().v0 = dp[i-2].back().v1;
sum = 0;
for (auto &x:dp[i]){
sum += x.w;
x.v0 += sum;
}
ptr = sz(dp[i])-1;
max1 = -INF;
for (ll j = sz(dp[i+1])-2;j >= 0;j --){
auto &x = dp[i+1][j];
while (dp[i][ptr].y > x.y){
sum -= dp[i][ptr].w;
max1 = max(max1,dp[i][ptr].v0);
ptr--;
}
x.v0 = max1 - sum;
// cout<<"V0 "<<x.y<<' '<<x.v0<<'\n';
}
dp[i-1].back().v1 = max(dp[i-1].back().v1,dp[i-2].back().v1);
// cout<<"V1 "<<dp[i-1].back().v1<<'\n';
}
return max(dp[n-1].back().v1,dp[n+1][0].v0);
}
# | 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... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |