码迷,mamicode.com
首页 > 其他好文 > 详细

ARC096D Static Sushi 记录前缀最大值

时间:2018-05-10 01:06:45      阅读:177      评论:0      收藏:0      [点我收藏+]

标签:顺时针   str   names   space   +=   amp   http   逆时针   typedef   

传送门ARC096D

思路:枚举 + 记录前缀最大值

我们考虑先逆时针走。

枚举逆时针的步数i,那么我们先从0->n+1-i,然后回到起点n+1-i->0

然后顺时针走,加上前缀最大值preMax[n-i]就好了。

先顺时针走同理。

code

#include <iostream>
using namespace std;
typedef long long LL;
const int N = 100000+10;
const LL INF = 1e16;

int n; 
LL c, x[N], v[N];
LL w[N], preMax[N];

LL solve() {
    preMax[0] = -INF;
    for(int i=1;i<=n;i++) {
        w[i]=v[i]-(x[i]-x[i-1]);
        w[i]=w[i-1]+w[i];
        preMax[i]=max(preMax[i-1],w[i]);
    }
    LL ret = -INF;
    ret = preMax[n];

    LL sum = 0;
    for(int i=n;i>=1;i--) {
        sum += v[i];
        ret=max(ret, sum-2*(c-x[i])+preMax[i-1]);
    }
    return ret;
}
int main() {
    scanf("%d %lld",&n,&c);
    for(int i=1;i<=n;i++) 
        scanf("%lld %lld", &x[i], &v[i]);
    LL ans = max(solve(),0LL);

    for(int i=1;i<=n;i++)
        if(i<n+1-i) {
            swap(x[i],x[n+1-i]);
            swap(v[i],v[n+1-i]);
        }
    for(int i=1;i<=n;i++)
        x[i]=c-x[i];
    ans = max(ans,solve());
    cout<<ans<<endl;
}

ARC096D Static Sushi 记录前缀最大值

标签:顺时针   str   names   space   +=   amp   http   逆时针   typedef   

原文地址:https://www.cnblogs.com/RUSH-D-CAT/p/9017452.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!