背包系列

        庆功会(ssl 2289)

Description

为了庆贺班级在校运动会上取得第一名的成绩,班主任决定开一场庆功会,为此拔款购买奖品奖励运动员,期望拔款金额能购买最大价值的奖品,可以补充他们的精力和体力。

Input

第一行二个数n(n<=500),m(m<=5000),其中n代表希望购买的物品的种数,m表示班会拨的钱数。
接下来n行,每行3个数,v、w、s,分别表示第I种物品的价格、价值(价格 与 价值 是不同的概念)和购买的数量(只能买0件或s件),其中v<=100,w<=1000,s<=10

Output

第一行:一个数,表示此次购买能获得的最大的价值(注意!不是价格)。

Sample Input

 

5 1000
80 20 4
40 50 9
30 50 7
20 20 1

 

Sample Output

 

1040

解题方法

01背包改一改就可以了。

代码

#include<iostream> 
using namespace std; 
int a[501],b[501],f[6001],m,n,j,s[501]; 
int main() 
{ cin>>n>>m; for (int i=1;i<=n;i++) { cin>>a[i]>>b[i]>>s[i];} for (int i=1;i<=n;i++) for (int c=m;c>=a[i];c--) for(int k=0;k<=s[i];k++)//循环种数 { if (c-a[i]*k<0) break; //判断有没有越界 f[c]=max(f[c],f[c-a[i]*k]+b[i]*k); //c不变,代价和价值乘种数 } cout<<f[m]; 
}

 

二进制优化

 

 
#include<iostream> 
using namespace std; 
int f[6001],a[1001],b[1001],n,m,u; 
int main() 
{ cin>>n>>m; for (int i=1;i<=n;i++) { int x,y,s,t=1; cin>>x>>y>>s; while (s>t) { a[++u]=x*t;//分成不同数量的物品,并保证可以合成最大数以下的任意一个数 b[u]=y*t; s=s-t; t=t*2; } a[++u]=x*s;//余数 b[u]=y*s; } for (int i=1;i<=u;i++) for (int j=m;j>=a[i];j--) f[j]=max(f[j],f[j-a[i]]+b[i]);//01背包 cout<<f[m]; 
}

 

 

 

      混合背包(ssl 2301)

 

Description

背包体积为V ,给出N个物品,每个物品占用体积为Vi,价值为Wi,每个物品要么至多取1件,要么至多取mi件(mi > 1) , 要么数量无限 , 在所装物品总体积不超过V的前提下所装物品的价值的和的最大值是多少?

Input

第一行两个数V,N下面N行每行三个数Vi,Wi,Mi表示每个物品的体积,价值与数量,Mi=1表示至多取一件,Mi>1表示至多取Mi件,Mi=0表示数量无限

Output

1个数Ans表示所装物品价值的最大值

Sample Input

 

10 3
2 1 0
3 3 1
4 5 4

 

Sample Output

 

11

 

解题方法

在循环里加一个判断,是0用完全背包,不是0用多重背包。

代码

 

#include<iostream>
using namespace std;
int a[501],b[501],f[6001],m,n,j,s[501];
int main()
{
cin>>m>>n;
for (int i=1;i<=n;i++){cin>>a[i]>>b[i]>>s[i];}
for (int i=1;i<=n;i++)if (s[i]==0)//判断是多重背包还是完全背包for (int c=a[i];c<=m;c++)//完全背包f[c]=max(f[c],f[c-a[i]]+b[i]); else for (int c=m;c>=a[i];c--)//多重背包for(int k=0;k<=s[i];k++){if (c-a[i]*k<0) break;//判断有没有越界 f[c]=max(f[c],f[c-a[i]*k]+b[i]*k); }           
cout<<f[m];
}

 

 

 

 

 

 

      分组背包(ssl 2291)

 

Description

有N件物品和一个容量为V的背包。第i件物品的费用是c[i],价值是w[i]。这些物品被划分为若干组,每组中的物品互相冲突,最多选一件。求解将哪些物品装入背包可使这些物品的费用总和不超过背包容量,且价值总和最大。

Input

第一行:三个整数,v(背包容量,v<=200),n(物品数量,n<=30)和t(最大组号,t<=10);
第2..n+1行:每行三个整数wi,ci,p,表示每个物品的重量、价值、所属组号。

Output

仅一行,一个数,表示最大总价值。

Sample Input

 

10 6 3
2 1 1
3 3 1
4 8 2
6 9 2 
2 8 3
3 9 3

 

Sample Output

 

20

解题方法

把同组的放在一个数组里,再加多一个循环就可以了。

代码

 

#include<iostream>
using namespace std;
int v,y,u,a[300][300],b[300][300],f[1000],p[11],m,n,t;
int main()
{
for (int i=1;i<=10;i++)p[i]=0;
cin>>m>>n>>t;
for (int i=1;i<=n;i++){cin>>v>>y>>u;a[u][++p[u]]=v;//p[u]用于放第u组有多少个物品b[u][p[u]]=y;//第u组第p[u]个的价格和价值}
for (int i=1;i<=t;i++)//第几组for (int j=m;j>=0;j--)for (int c=1;c<=p[u];c++)//第几个if (j>=a[i][c])//判断有没有越界f[j]=max(f[j],f[j-a[i][c]]+b[i][c]);
cout<<f[m];
}

 

 

 

 

 

          货币系统(ssl 1115)

 

Description

母牛们不但创建了他们自己的政府而且选择了建立了自己的货币系统。
[In their own rebellious way],他们对货币的数值感到好奇。
传统地,一个货币系统是由1,5,10,20 或 25,50, 和 100的单位面值组成的。
母牛想知道有多少种不同的方法来用货币系统中的货币来构造一个确定的数值。
举例来说, 使用一个货币系统 {1,2,5,10,...}产生 18单位面值的一些可能的方法是:18x1, 9x2, 8x2+2x1, 3x5+2+1,等等其它。
写一个程序来计算有多少种方法用给定的货币系统来构造一定数量的面值。
保证总数将会适合long long (C/C++) 和 Int64 (Free Pascal)。

Input

货币系统中货币的种类数目是 V 。 (1<= V<=25)
要构造的数量钱是 N 。 (1<= N<=10,000)
第 1 行: 二整数, V 和 N
第 2 ..V+1行: 可用的货币 V 个整数 (每行一个 每行没有其它的数)。

Output

单独的一行包含那个可能的构造的方案数。
末尾有空行

Sample Input

 

3 10
1 2 5

 

Sample Output

 

10

解题方法

累加之前的组数就可以了。

代码

 
#include<iostream> 
using namespace std; 
int m,n,a[30]; 
long long f[10100]; 
int main() 
{ cin>>m>>n; for (int i=1;i<=m;i++) cin>>a[i]; f[0]=1;//预处理 for (int i=1;i<=m;i++) for (int j=a[i];j<=n;j++) f[j]=f[j]+f[j-a[i]];//用a[i]的钱时等于其他钱组成的种数加上用a[i]之前的种数 cout<<f[n]; 
} 

 

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/321550.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用TFS CI/CD 完成 VSTS 插件自动化部署和发布

Visual Studio Team Service 经过了13年的版本演进和5年的在线运营&#xff0c;现在已经是最成熟的商用DevOps工具链&#xff0c;Marketplace作为VSTS为全球开发者提供各种类型的插件市场&#xff0c;为Visual Studio, Visual Studio Code和Visual Studio Team Service本身提供…

P4248-[AHOI2013]差异【SAM or SA】

正题 题目链接:https://www.luogu.com.cn/problem/P4248 题目大意 TiT_iTi​表示后缀i∼ni\sim ni∼n 一个字符串求 ∑i1n∑jinlen(Ti)len(Tj)−2∗lcp(Ti,Tj)\sum_{i1}^n\sum_{ji}^nlen(T_i)len(T_j)-2*lcp(T_i,T_j)i1∑n​ji∑n​len(Ti​)len(Tj​)−2∗lcp(Ti​,Tj​) 解题…

14、ORACLE下的基本SQL操作

ORACLE下的基本SQL操作 1.获取表字段 select * from user_tab_columns where Table_Name用户表 order by column_name2.获取表注释 select * from user_tab_comments where Table_Name用户表 order by Table_Name3.获取字段注释 select * from user_col_comments where Table_…

暗黑破坏神(ssl 2295)

暗黑破坏神&#xff08;ssl 2295&#xff09; Description 无聊中的小x玩起了Diablo I... 游戏的主人公有n个魔法 每个魔法分为若干个等级&#xff0c;第i个魔法有p[i]个等级(不包括0) 每个魔法的每个等级都有一个效果值&#xff0c;一个j级的i种魔法的效果值为w[i][j] 魔法升…

用C# (.NET Core) 实现迭代器设计模式

本文的概念来自深入浅出设计模式一书项目需求有两个饭店合并了, 它们各自有自己的菜单. 饭店合并之后要保留这两份菜单.这两个菜单是这样的:菜单项MenuItem的代码是这样的:最初我们是这样设计的, 这是第一份菜单:这是第2份菜单:同时有两个菜单存在的问题问题就是多个菜单把事情…

P4287-[SHOI2011]双倍回文【PAM】

正题 题目链接:https://www.luogu.com.cn/problem/P4287 题目大意 长度为nnn的字符串。定义wRw^RwR表示字符串www的翻转。 一个双倍回文可以表示为wwRwwRww^Rww^RwwRwwR且这是个回文串。 求最长的子串是双倍回文。 解题思路 我们在构建PAMPAMPAM的时候维护一个halfhalfhal…

2020-09-18

1.处理调用子组件方法时&#xff0c;报错undefined问题 2.var 、const 、let区别 3. curl -X GET --header "Accept: */*" "访问地址" 4.mysql中的日期格式化 5. ant-design-vue-jeecg

低价购买(洛谷 1108)

低价购买&#xff08;洛谷 1108&#xff09; 题目描述 “低价购买”这条建议是在奶牛股票市场取得成功的一半规则。要想被认为是伟大的投资者&#xff0c;你必须遵循以下的问题建议:“低价购买&#xff1b;再低价购买”。每次你购买一支股票,你必须用低于你上次购买它的价格购…

.NET Core/.NET之Stream简介

之前写了一篇C#装饰模式的文章用.NET Core实现装饰模式和.NET Core的Stream简介 提到了.NET Core的Stream, 所以这里尽量把Stream介绍全点. (都是书上的内容).NET Core/.NET的Streams首先需要知道, System.IO命名空间是低级I/O功能的大本营.Stream的结构.NET Core里面的Stream主…

P4762-[CERC2014]Virus synthesis【PAM,dp】

正题 题目链接:https://www.luogu.com.cn/problem/P4762 题目大意 长度为nnn的目标串&#xff0c;开始一个空串&#xff0c;可以执行以下操作 在头或者尾加一个字符复制一个该串的逆串放在后面 求最少操作次数。 解题思路 我们可以知道答案肯定是一个回文串然后剩下的暴力…

I - Trade Gym - 100212I 网络流

网络流好题 给出A、B两个点集&#xff0c;A、B之间有边相连&#xff0c;而A和B的内部均无边相连。 题目要求求出最多删除A、B之间的多少边&#xff0c;才能使得A中点的度数至少都为2&#xff0c;B中点的度数也至少都为2。 先求出每个点的度数&#xff0c;从每个点v出发&…

1、Spring简介

1、Spring是什么&#xff1f; Spring是一套用于开发J2EE应用程序的轻量级框架&#xff0c;其两大核心是IOC和AOP&#xff0c;也就是提供一个bean统一管理容器&#xff0c;提供面向切面编程的基础。 2、为什么要用Spring&#xff1f; 1&#xff09;使用Spring肯定是为了简化开…

【深搜】骑士游历(ssl 1277)

骑士游历 Description 如下图所示有m*n(n,m<15)一个棋盘&#xff0c;在棋盘左下角的A&#xff08;1,1&#xff09;点&#xff0c;有一个中国象棋〈马〉&#xff0c;并约定马走的规则&#xff1a; ①走日字&#xff1b;②只能向右走。 Sample Input &#xff19; &…

P6015-[CSGRound3]游戏【树状数组】

正题 题目链接:https://www.luogu.com.cn/problem/P6015?contestId25945 题目大意 nnn张牌&#xff0c;玩家111从顶拿若干张&#xff0c;之后玩家222拿若干张。 若牌的和大于KKK那么分数为0否则为牌的和。 求KKK为多少时玩家111必胜。 解题思路 我们枚举玩家111拿多少张&a…

修复迁移后Net Standard项目中的错误

接上一章&#xff0c;项目编译结果如下&#xff1a;解决依赖dll引用在Net Framework项目的引用如下&#xff1a;各引用和作用&#xff1a;log4net(1.10.0.0) 用于写框架日志Castle.DynamicProxy(1.1.5.1) 用于代理类生成Micosoft.Practice.EnterpiseLibrary 微软企业库&#xf…

【深搜】骑士游历(二)

骑士游历&#xff08;二&#xff09; 问题描述&#xff1a;设有一个nn的棋盘&#xff08;n≤10&#xff09;&#xff0c;在棋盘上的任意一点A(x,y)有一中国象棋<马>,<马>走的规则同前&#xff0c;但取消<马>只能向右走的条件。试找出一条路径&#xff0c;使…

P3449-[POI2006]PAL-Palindromes【结论题,字符串hash】

正题 题目链接:https://www.luogu.com.cn/problem/P3449 题目大意 nnn个回文串&#xff0c;求有多少对回文串有序拼接可以形成一个新的回文串。 解题思路 结论:当两个回文串的最短循环节相同时两个拼接起来就是一个新的回文串。 这里感性证明一下&#xff1a; 若两个回文串…

迁移Net项目为Net Core\Standard项目

背景&#xff1a;我们公司内部有自己ORM开发框架&#xff0c;最新因为需要将系统迁移到国产服务器上&#xff0c;所以首先需要将最基础的ORM框架改造可以运行在国产服务器上。对于我们Net来说&#xff0c;优选Net Core。在迁移的过程中&#xff0c;将一些经验和坑记录下来&…

2-sat模板- 输出可行解

自己写的代码 using namespace std; const int maxn 1e6; int head[maxn]; int DFN[maxn],LOW[maxn],stk[maxn],visit[maxn],belong[maxn]; vector<int> scc[maxn]; int tot,idx,cnt,sccnum; int n,color[maxn],degree[maxn],pos[maxn]; struct Es{ int v; int next; in…

读从电子到产品

1、用户的量不重要&#xff0c;质更重要&#xff0c;要让用户真正跟你的产品产生很强大的关系&#xff0c;要看解决问是不是够好、够快、够准&#xff0c;在解决问题的时候&#xff0c;要保证产品真正能满足用户的需求。 2、你认为的问题&#xff0c;别人未必觉得是问题&#…