题目:
代码:
#include<bits/stdc++.h>
using namespace std;
const int N=100010,INF=0x3f3f3f3f;
int n;
int w[N];
int f[N][3];
//f[i][0] 有货
//f[i][1] 没货第一天
//f[i][2] 没货第二天
int main(){
cin>>n;
for(int i=1;i<=n;i++)cin>>w[i];
f[0][0]=f[0][1]=-INF,f[0][2]=0;
for(int i=1;i<=n;i++){
f[i][0]=max(f[i-1][0],f[i-1][2]-w[i]);
f[i][1]=f[i-1][0]+w[i];
f[i][2]=max(f[i-1][2],f[i-1][1]);
}
cout<<max(f[n][1],f[n][2]);
return 0;
}