背包问题模板

原创 2015年02月12日 23:13:20

算法源于《背包九讲》

下面是实现代码:

#include<cstdio>
#include<cstring>
#include<cmath>
#include<cstdlib>
#include<iostream>
#include<algorithm>
#include<sstream>
#include<vector>
#include<map>
#include<stack>
#include<list>
#include<set>
#include<queue>
#define LL long long
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1 | 1
using namespace std;
const int maxn=100005;
int w[maxn],v[maxn],num[maxn];//代价数组和价值数组,以及相应的物品最大件数
int W,n;//背包容量和物品件数
int dp[maxn];//背包更新数组
void ZeroOnePack(int weight,int value)//0-1背包
{
    for(int i=W;i>=weight;i--)
        dp[i]=max(dp[i],dp[i-weight]+value);
}
void CompletePack(int weight,int value)//完全背包
{
    for(int i=weight;i<=W;i++)
        dp[i]=max(dp[i],dp[i-weight]+value);
}
void MultiplePack(int weight,int value,int cnt)//多重背包
{
    if(weight*cnt>=W) CompletePack(weight,value);
    else
    {
        for(int k=1;k<cnt;k<<=1)
            ZeroOnePack(k*weight,k*value),cnt-=k;
        ZeroOnePack(cnt*weight,cnt*value);
    }
}
int main()
{
    //读入数据
    return 0;
}


版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

背包问题模板 hdu2191

  • 2014-06-24 09:56
  • 12KB
  • 下载

二维背包问题 + 代码模板

 二维费用的背包问题是指:对于每件物品,具有两种不同的费用;选择这件物品必须同时付出这两种代价;对于每种代价都有一个可付出的最大值(背包容量)。问怎样选择物品可以得到最大的价值。设这两种代价分别...

HDU2546【01背包问题模板题】

饭卡 Time Limit: 5000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submi...

背包问题模板

01背包模板 int main() { int i, j, n, m; while(scanf("%d",&n)!=EOF) { scan...

【NOIP模板①】经典DP——背包问题

关于背包,我相信任何一个对OI小有涉猎的人

背包问题标准模板

背包问题很多都可以转化为基本的01背包或者完全背包来解决,所以在弄懂之后写一套背包问题的模板备用也是十分有必要的~这是我写的模板,当遇到具体问题还需要具体对待,比如果什么是“价值”什么是“重量”什么是...

背包问题--0/1背包 【模板】

首先01背包题目的雏形是 有N件物品和一个容量为V的背包。第i件物品的费用是c[i],价值是w[i]。求解将哪些物品装入背包可使价值总和最大。 从这个题目中可以看出,01背包的特点就是:每种物品仅...

背包问题九讲

  • 2017-05-14 20:19
  • 31KB
  • 下载

0-1背包问题

  • 2017-09-11 23:55
  • 38KB
  • 下载

模板①:背包问题(0-1背包&完全背包&多重背包)

鉴于NOIP临近,打算来写写模板
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)