题目链接:
[HDU 1300]Pearls[DP]
题意分析:
总共有C种等级的珍珠,每种需要买a[i]个,单个价格为p[i]元,如果想要买某种等级的珍珠,需要先交付10个该等级珍珠的价格才能进行购买,允许使用高等级珍珠替换需要买的低等级珍珠。问:要达到采购需求,最少需要花费多少的经费?(等级越高,单价越高:)
解题思路:
设dp[i]代表到第i种等级的珍珠,需要花费的最少费用。那么初始化为INF, dp[0] = 0。有转移:dp[i] = min(dp[i], dp[j] + (sum[i] - sum[j] + 10) * p[i])。sum为到第i个为止所需要购买的珍珠数。
个人感受:
贪心、费用流,都用上了,哈哈哈哈哈。贪心不成,建图失败。这道题我也是醉了。然后听他们的才知道是动态规划= =。
具体代码如下:
#include<algorithm>
#include<cctype>
#include<cmath>
#include<cstdio>
#include<cstring>
#include<iomanip>
#include<iostream>
#include<map>
#include<queue>
#include<set>
#include<sstream>
#include<stack>
#include<string>
#define ll long long
#define pr(x) cout << #x << " = " << (x) << '\n';
using namespace std;
const int INF = 0x7f7f7f7f;
const int MAXN = 211;
int a[MAXN], p[MAXN], sum[MAXN], dp[MAXN];
int main()
{
int kase, n; scanf("%d", &kase);
while (kase --) {
scanf("%d", &n);
sum[0] = 0;
for (int i = 1; i <= n; ++i) {
scanf("%d%d", &a[i], &p[i]);
sum[i] = sum[i - 1] + a[i];
dp[i] = INF;
}
dp[0] = 0;
for (int i = 1; i <= n; ++i) {
for (int j = 0; j < i; ++j)
dp[i] = min(dp[i], dp[j] + (sum[i] - sum[j] + 10) * p[i]);
}
printf("%d\n", dp[n]);
}
return 0;
}
本文讨论了使用动态规划解决采购不同等级珍珠时,如何以最少的经费完成任务的问题。通过设置状态转移方程,优化采购策略,实现成本最小化。

279

被折叠的 条评论
为什么被折叠?



