[HDU 1300]Pearls[DP]

题目链接: [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;
}


你可能感兴趣的:(dp)