zoukankan      html  css  js  c++  java
  • 完全背包 poj 1384

    #include<cstdio>
    #include<cmath>
    #include<iostream>
    #include<conio.h>
    using namespace std;
    const int maxn=500;
    const int maxdp=10010;
    int p[maxn],w[maxn];
    int dp[maxdp];

    int main()
    {
     //freopen("in.txt","r",stdin);
     int t;
     scanf("%d",&t);                                             //次数
     while(t--){
      int w1,sum,n;scanf("%d%d%d",&w1,&sum,&n);
      sum-=w1;                                                //背包容量
      for(int i=0;i<n;i++)scanf("%d%d",&p[i],&w[i]);          //每种金币数据          
      memset(dp,-1,sizeof(int)*(sum+1));                      //dp值清为-1  为完全背包的前提条件
      dp[0]=0;                                                //dp[0]为没有价值的情况 清为零 初始化
      for(int i=0;i<n;i++){                                   //0-n
       for(int j=w[i];j<=sum;j++){                         //完全背包   j=w[i]   w为金币的重量   自家
        if(dp[j]!=-1&&dp[j-w[i]]!=-1)dp[j]=min(dp[j],dp[j-w[i]]+p[i]);      //状态转移判断
        else if(dp[j-w[i]]!=-1)dp[j]=dp[j-w[i]]+p[i];
       }
      }
      if(dp[sum]==-1)puts("This is impossible.");              //输出
      else printf("The minimum amount of money in the piggy-bank is %d.\n",dp[sum]);
     }
     
    }

  • 相关阅读:
    boke
    Http post/get
    记一次网站优化---图片压缩与移动端画面缩放问题
    深入浅出 Vue.js 第九章 解析器---学习笔记
    Linux/Mac中alias的使用
    JavaScript中的函数柯里化与反柯里化
    JavaScript中深拷贝实现
    JavaScript中的节流和防抖
    博客园加入百度统计遇到的坑
    记一次无数据库下动态更新文案的解决历程
  • 原文地址:https://www.cnblogs.com/amourjun/p/5134197.html
Copyright © 2011-2022 走看看