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;
}