#include using namespace std; const int INF = 0x3f3f3f3f; const int N = 1e5 + 10, M = 110; int n, k; int w[N]; int f[N][M][2]; // 以卖出做为一次完整交易的分界线 // f[i][j][0/1]定义成 前i天 完成最多是j次交易 且 决策为0/1的集合 int main() { cin >> n >> k; for (int i = 1; i <= n; i++) cin >> w[i]; memset(f, -0x3f, sizeof f); for (int i = 0; i <= n; i++) f[i][0][0] = 0; for (int j = 0; j <= n; j++) f[0][j][0] = 0; // 下面两句,由于整体进行了初始化,就变得可以省略了 // for (int i = 0; i <= n; i++) f[i][0][1] = -INF; // for (int j = 0; j <= n; j++) f[0][j][1] = -INF; for (int i = 1; i <= n; i++) { for (int j = 0; j <= k; j++) { if (j) f[i][j][0] = max(f[i - 1][j][0], f[i - 1][j - 1][1] + w[i]); f[i][j][1] = max(f[i - 1][j][1], f[i - 1][j][0] - w[i]); } } cout << f[n][k][0] << endl; return 0; }