题目:题目链接
题目意思:
从一列数字中按照编号从小到大有选择的取数,若取到的数字的为第奇数个则加上该数,否则减去该数,问取到的数的
最大总和。
解题方法:
动态规划:
dp[i][0] = max(dp[i - 1][0], dp[i - 1][1] + num[i])表示当前是第奇数个;
dp[i][1] = max(dp[i - 1][1], dp[i - 1][0] - num[i])表示当前是第偶数个;
#include <iostream>
#include <cstdio>
#include <string>
#include <string.h>
#include <map>
#include <vector>
#include <cstdlib>
#include <cmath>
#include <algorithm>
#include <queue>
#include <set>
#include <stack>
using namespace std;
#define N 200000
int sum[N];
int dp[N][2];
int n;
int main()
{
scanf("%d", &n);
memset(sum, 0, sizeof(sum));
memset(dp, 0, sizeof(dp));
for(int i = 1; i <= n; ++i)
scanf("%d", &sum[i]);
for(int i = 1; i <= n; ++i)
{
dp[i][0] = max(dp[i-1][0], dp[i-1][1] + sum[i]);//偶数位
dp[i][1] = max(dp[i-1][1], dp[i-1][0] - sum[i]);//奇数位
//cout << i << ": "<< dp[i][0] <<' '<< dp[i][1] << endl;
}
printf("%d\n", max(dp[n][0], dp[n][1]));
return 0;
}