首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >NYOJ 311 完全背包(恰好装满)

NYOJ 311 完全背包(恰好装满)

作者头像
Ch_Zaqdt
发布2019-01-10 11:17:11
5930
发布2019-01-10 11:17:11
举报
文章被收录于专栏:Zaqdt_ACMZaqdt_ACM

就直接上代码吧,至于判断恰好装满问题可以看下这篇博客传送门(Piggy-Bank)

需要注意的是直接调用max函数会TLE,所以以后还是不要懒省事的直接调用max函数吧。

AC代码:

#include <iostream>
#include <cstring>
#include <cstdio>
#define MAX(a,b) a>b?a:b
using namespace std;
const int INF = 0x3f3f3f3f;
const int MAXN = 1000005;
int dp[MAXN];
int w[MAXN];
int val[MAXN];
int n,m,p;
int main()
{
  scanf("%d",&n);
  while(n--){
    scanf("%d%d",&m,&p);
    for(int i=0;i<m;i++){
      scanf("%d%d",&w[i],&val[i]);
    }
    memset(dp,-INF,sizeof(dp));
    dp[0] = 0;
    for(int i=0;i<m;i++){
      for(int j=w[i];j<=p;j++){
        dp[j]=MAX(dp[j],dp[j-w[i]]+val[i]);    // 尽量用宏定义或者三目运算符吧
      }
    }
    if(dp[m]<0){
      printf("NO\n");
    }
    else{
      printf("%d\n",dp[p]);
    }
  }
  return 0;
}
/*
  [来源] NYOJ 311
  [题目] 完全背包
  [大意]
     顾题目思义,就是一道完全背包问题,但是要判断是否恰好装满,详细可以看Piggy-Bank这个题解。唯一比较坑的是交了快十次,
     一直TLE,最后发现直接调用max比较函数会慢。
  [输入]
     2
     1 5
     2 2
     2 5
     2 2
     5 1
   [输出]
     NO
     1
*/
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018年02月10日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档