码迷,mamicode.com
首页 > 其他好文 > 详细

P1616 疯狂的采药 (完全背包优化)

时间:2019-09-03 16:48:36      阅读:68      评论:0      收藏:0      [点我收藏+]

标签:解决   names   man   优化   class   cost   str   完全   style   

(点击此处查看原题)

题意

简单来说,就是一个完全背包,不过这里卡住了常规的完全背包写法,时间复杂度为O( V*∑( V/c[i] ))如下所示:

for(int i = 1;i <= n ;i ++)
    {
        scanf("%d%d",cost+i,val+i);
        for(int j = t; j >= cost[i] ; j --)
        {
            for(int k = 1; k * cost[i] <= j ;k ++)
            {
                dp[j] = max(dp[j],dp[j-k*cost[i]] + k * val[i]);
            }
        }
    }

解题思路

既然普通的写法无法解决,那就采用如下的优化即可,时间复杂度为O(NV),题目满足N*T <= 1e7,因此可以跑过去:

for(int i = 1;i <= n ;i ++)
    {
        scanf("%d%d",cost+i,val+i);
        for(int j = cost[i]; j <= t; j ++)
        {
            dp[j] = max(dp[j],dp[j-cost[i]] + val[i]);
        }
    }

代码区

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<queue>
#include<string>
#include<fstream>
#include<vector>
#include<stack>
#include <map>
#include <iomanip>

#define bug cout << "**********" << endl
#define show(x, y) cout<<"["<<x<<","<<y<<"] "
#define LOCAL = 1;
using namespace std;
typedef long long ll;
const int inf = 1e9 + 7;
const ll mod = 1e9 + 7;
const int Max = 1e5 + 10;

int t, n;
int cost[Max],val[Max];
int dp[Max];            //记录价格为i的时候的最大价值

int main()
{
#ifdef LOCAL
    //    freopen("input.txt", "r", stdin);
    //    freopen("output.txt", "w", stdout);
#endif
    scanf("%d%d",&t,&n);
    memset(dp,0,sizeof(dp));
    for(int i = 1;i <= n ;i ++)
    {
        scanf("%d%d",cost+i,val+i);
        for(int j = cost[i]; j <= t; j ++)
        {
            dp[j] = max(dp[j],dp[j-cost[i]] + val[i]);
        }
    }
    printf("%d\n",dp[t]);
    return 0;
}

 

P1616 疯狂的采药 (完全背包优化)

标签:解决   names   man   优化   class   cost   str   完全   style   

原文地址:https://www.cnblogs.com/winter-bamboo/p/11453271.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!