博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
dp之完全背包 hdu--2159一维数组做法
阅读量:6123 次
发布时间:2019-06-21

本文共 641 字,大约阅读时间需要 2 分钟。

#include <iostream>

#include <stdio.h>
#include <string.h>
using namespace std;
int main()
{
    int n,m,t,s;
    int dp[205];
    int w[205];
    int v[205];
    int cnt[205];
    while(~scanf("%d %d %d %d",&n,&m,&t,&s))
    {
        memset(dp,0,sizeof(dp));
        memset(cnt,0,sizeof(cnt));
        for(int i=0;i<t;i++)
        {
            scanf("%d %d",&v[i],&w[i]);
        }
        for(int i=0;i<t;i++)
        {
            for(int j=w[i];j<=m;j++)//顺序,如果逆序的话就是01背包的问题了
            {
                if(dp[j]<dp[j-w[i]]+v[i])
                {
                    cnt[j]=cnt[j-1]+1;//如果多取一件东西的经验更多的话,就打怪次数增加
                    dp[j]=dp[j-w[i]]+v[i];
                }
            }
        }
        int ans=-1;
        for(int j=0;j<=m;j++)
        {
            if(dp[j]>=n&&cnt[j]<=s)
            {
                ans=m-j;
                break;
            }
        }
         cout<<ans<<endl;
    }
    return 0;
}

转载于:https://www.cnblogs.com/chinacwj/p/7053844.html

你可能感兴趣的文章
javascript性能优化
查看>>
多路归并排序之败者树
查看>>
java连接MySql数据库
查看>>
转:Vue keep-alive实践总结
查看>>
android studio修改新项目package名称
查看>>
深入python的set和dict
查看>>
C++ 11 lambda
查看>>
Hadoop2.5.0 搭建实录
查看>>
实验吧 recursive write up
查看>>
High-speed Charting Control--MFC绘制图表(折线图、饼图、柱形图)控件
查看>>
go test命令參数问题
查看>>
linux 搜索文本
查看>>
超实用Mac软件分享(二)
查看>>
Android JSON数据解析
查看>>
DEV实现日期时间效果
查看>>
java注解【转】
查看>>
Oracle表分区
查看>>
centos 下安装g++
查看>>
嵌入式,代码调试----GDB扫盲
查看>>
类斐波那契数列的奇妙性质
查看>>