题解:P11793 [JOI 2016 Final] 橙子装箱 / Oranges
题目分析
有
解题思路
使用动态规划(DP)求解:
设
其中
- 初始状态:
dp[0] = 0 (没有橙子时成本为 0)。 - 边界处理:当
j < 0 时跳过。
在实现时,内层循环从
代码实现
#include <bits/stdc++.h>
using namespace std;
int main() {
ios::sync_with_stdio(false);
cin.tie(0);
int n, m, k;
cin >> n >> m >> k;
vector<int> A(n + 1);
for (int i = 1; i <= n; i++) {
cin >> A[i];
}
vector<long long> dp(n + 1, LLONG_MAX);
dp[0] = 0;
for (int i = 1; i <= n; i++) {
int min_val = A[i];
int max_val = A[i];
for (int j = i - 1; j >= max(0, i - m); j--) {
if (A[j + 1] < min_val) min_val = A[j + 1];
if (A[j + 1] > max_val) max_val = A[j + 1];
long long cost = k + 1LL * (i - j) * (max_val - min_val);
if (dp[j] != LLONG_MAX) {
if (dp[j] + cost < dp[i]) {
dp[i] = dp[j] + cost;
}
}
}
}
cout << dp[n] << endl;
return 0;
}