百炼oj 48:移动办公

48:移动办公

总时间限制:

1000ms

内存限制:

65536kB

描述

假设你经营着一家公司,公司在北京和南京各有一个办公地点。公司只有你一个人,所以你只能每月选择在一个城市办公。在第i个月,如果你在北京办公,你能获得Pi的营业额,如果你在南京办公,你能获得Ni的营业额。但是,如果你某个月在一个城市办公,下个月在另一个城市办公,你需要支付M的交通费。那么,该怎样规划你的行程(可在任何一个城市开始),才能使得总收入(总营业额减去总交通费)最大?

输入

输入的第一行有两个整数T(1 <= T <= 100)和M(1 <= M <= 100),T代表总共的月数,M代表交通费。接下来的T行每行包括两个在1到100之间(包括1和100)的的整数,分别表示某个月在北京和在南京办公获得的营业额。

输出

输出只包括一行,这一行只包含一个整数,表示可以获得的最大总收入。

样例输入

4 3
10 9
2 8
9 5
8 2

样例输出

31
#include <iostream>
#include <string.h>
#include <cmath>
#include <queue>
#include <map>
#include <cstdio>
using namespace std;
const int INF = 999999999;
int a[1050];
int b[1050];
int dp1[1050];
int dp2[1050];
int dp[1050];
int main(){
    int n,m;
    cin >> n >> m;
    for(int i = 1;i <= n;i++){
        cin >> a[i] >> b[i];
    }
    dp1[1] = a[1];
    dp2[1] = b[1];
    dp[1] = max(a[1],b[1]);
    for(int i = 2;i <= n;i++){
        dp1[i] = max(dp1[i-1] + a[i],dp2[i-1] + a[i] - m);
        dp2[i] = max(dp2[i-1] + b[i],dp1[i-1] + b[i] - m);//昨天一直wa今天突然发现自己傻逼了一定要搞清楚状态到底是怎么转移的 昨天a,b写反了没看出来
        dp[i] = max(dp1[i],dp2[i]);
    }
    cout << dp[n] << endl;

}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值