背包例题【dp练习】

ssl2289-庆功会

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

解题思路

  枚举一下选的组数就好了,可以二进制优化。


代码

#include<cstdio>
#include<iostream>
using namespace std;
int n,m,w[501],c[501],s[501],f[6001];
int main()
{scanf("%d%d",&n,&m);for (int i=1;i<=n;i++) scanf("%d%d%d",&w[i],&c[i],&s[i]);for (int i=1;i<=n;i++)for (int j=m;j>=0;j--)for (int k=0;k<=s[i];k++)//枚举组数{if (j-k*w[i]<0) break;//判断越界f[j]=max(f[j],f[j-k*w[i]]+k*c[i]);}printf("%d",f[m]);
}


二进制优化代码

#include<cstdio>
#include<iostream>
using namespace std;
int n,m,w[10001],c[10001],f[6001],n1;
int main()
{scanf("%d%d",&n,&m);for (int i=1;i<=n;i++) {int x,y,s,t=1;scanf("%d%d%d",&x,&y,&s);while (s>=t){w[++n1]=x*t;c[n1]=y*t;s-=t;t*=2;}w[++n1]=x*s;c[n1]=y*s;//二进制优化}for (int i=1;i<=n1;i++)for (int j=m;j>=w[i];j--)f[j]=max(f[j],f[j-w[i]]+c[i]);printf("%d",f[m]);
}


ssl2301-混合背包

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

解题思路

混合背包,就是多重加完全罢了。


代码

#include<cstdio>
#include<iostream>
using namespace std;
int n,m,w[31],c[31],f[201],s[31];
int main()
{scanf("%d%d",&m,&n);for (int i=1;i<=n;i++) {scanf("%d%d%d",&w[i],&c[i],&s[i]);}for (int i=1;i<=n;i++)if (s[i]==0){for (int j=w[i];j<=m;j++)f[j]=max(f[j],f[j-w[i]]+c[i]);}//完全背包else{for (int j=1;j<=s[i];j++)for (int k=m;k>=w[i];k--)f[k]=max(f[k],f[k-w[i]]+c[i]);}//多重printf("%d",f[m]);
}


ssl2291-分组背包

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<cstdio>
#include<iostream>
using namespace std;
int w[31],c[31],a[11][32],f[201],m,n,t,p;
int main()
{scanf("%d%d%d",&m,&n,&t);for (int i=1;i<=n;i++){scanf("%d%d%d",&w[i],&c[i],&p);a[p][++a[p][0]]=i;//分组}for (int i=1;i<=t;i++)for (int j=m;j>=0;j--)for (int k=1;k<=a[i][0];k++)//枚举选的组数if (j>=w[a[i][k]])//避免越界{f[j]=max(f[j],f[j-w[a[i][k]]]+c[a[i][k]]);//动态转移}printf("%d",f[m]);
}

ssl1115-货币系统

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<cstdio>
using namespace std;
int a[10001],n,m;
long long f[10001];
int main()
{scanf("%d%d",&n,&m);for (int i=1;i<=n;i++)scanf("%d",&a[i]);//输入f[0]=1;//预处理for (int i=1;i<=n;i++)for (int j=a[i];j<=m;j++)f[j]+=f[j-a[i]];//方案数累加printf("%lld",f[m]);
}


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

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

相关文章

MyBatis中Mapper代理方式

Mapper 的动态代理作用 目前使用sqlsession进行增删改查的缺点&#xff1a; [1]没有办法实现多参数的传递 [2]书写的时候没有接口&#xff0c;后期的维护就比较的低 解决的方案&#xff1a; Mapper的代理方式实现增删改查 接口代码 public interface FlowerMapper {//查询所有…

《走遍中国》珍藏版(十二)

Console.WriteLine("上一本书已经看完&#xff0c;从今天开始看下一本"); System.out.println("《走遍中国》珍藏版"); System.out.println("这本书是关于地理的"); System.out.println("地理往往是和历史进行紧密联系的");这里的水底…

View Components as Tag Helpers,离在线模板编辑又进一步

在asp.net core mvc中增加了ViewComponent&#xff08;视图组件&#xff09;的概念&#xff0c;视图组件有点类似部分视图&#xff0c;但是比部分视图功能更加强大&#xff0c;它更有点像一个控制器。 使用方法 1&#xff0c;定义类派生自ViewComponent类 2&#xff0c;增加…

JavaFX UI控件教程(九)之Text Field

翻译自 Text Field 本章讨论文本字段控件的功能。 的TextField类实现接受并显示文本输入的UI控制。它提供了从用户接收文本输入的功能。与另一个文本输入控件一起&#xff0c;PasswordField此类扩展了TextInput类&#xff0c;它是通过JavaFX API提供的所有文本控件的超类。…

VS

&—逻辑与 | —逻辑或 &#xff01;—逻辑非 && —短路与 || —短路或 ^ —逻辑异或

MyBatis中动态SQL

01为什么使用sql语句的动态拼接 目前学习的内容sql语句都是直接写死的&#xff0c;但是在实际的开发过程中很多的sql语句都是根据不同的业务情况进行不同的改变的 02 解决的方案 sql语句的动态拼接 03学习的标签 if where when set trim foreach bind include sql 接口代码1 p…

ssl1643-最小乘车费用【dp练习】

最小乘车费用 题目 假设某条街上每一公里就有一个公共汽车站&#xff0c;并且乘车费用如下表&#xff1a;      而任意一辆汽车从不行驶超过10公里。某人想行驶n公里&#xff0c;假设他可以任意次换车&#xff0c;请你帮他找到一种乘车方案&#xff0c;使得总费用最小 …

JavaFX UI控件教程(十)之Scroll Bar

翻译自 Scroll Bar 本章介绍如何使用滚动条控件创建可滚动窗格。 本ScrollBar类可以在应用程序中创建滚动窗格和意见。图9-1显示了滚动条的三个区域&#xff1a;拇指&#xff0c;右侧和左侧按钮&#xff08;或向下和向上按钮&#xff09;以及轨道。 图9-1滚动条的元素 创建…

《走遍中国》珍藏版(十三)

Console.WriteLine("上一本书已经看完&#xff0c;从今天开始看下一本"); System.out.println("《走遍中国》珍藏版"); System.out.println("这本书是关于地理的"); System.out.println("地理往往是和历史进行紧密联系的");一游衡山&a…

a+=b不一定等于a=a+b

说明不会改变本身变量的数据类型与&#xff0c;–运算符一样

Jexus部署.Net Core项目

Jexus Jexus 即 Jexus Web Server&#xff0c;简称JWS&#xff0c;是Linux平台上 的一款ASP.NET WEB服务器。它是 Linux、Unix、FreeBSD 等非Windows系统架设 ASP.NET WEB 服务器的核心程序。 将HTTP自宿主应用程序&#xff08;如Asp.net Core应用程序、Node.js应用程序等&…

MyBatis中增删改操作

Mapper层代码 <!-- 增加操作 public int insert (Flower fl) --> <insert id"insert"> insert into flower values(default,#{name},#{price},#{production}) </insert> <!--修改操作 public int update(…

JavaFX UI控件教程(十一)之Scroll Pane

翻译自 Scroll Pane 在本章中&#xff0c;您将学习如何在JavaFX应用程序中构建滚动窗格。 滚动窗格提供UI元素的可滚动视图。此控件使用户可以通过平移视口或使用滚动条来滚动内容。具有默认设置和添加的图像的滚动窗格如图10-1所示。 图10-1滚动窗格 创建滚动窗格 示例10…

洛谷【P2758】-编辑距离

题目描述 设A和B是两个字符串。我们要用最少的字符操作次数&#xff0c;将字符串A转换为字符串B。这里所说的字符操作共有三种&#xff1a; 1、删除一个字符&#xff1b; 2、插入一个字符&#xff1b; 3、将一个字符改为另一个字符&#xff1b; &#xff01;皆为小写字母&…

交换两个数字的三种方式

package com.wdl.day01;public class HelloJava {public static void main(String[] args) {int num11;int num22;//方式一&#xff1a;定义临时变量 // int tempnum1; // num1num2; // num2temp;//方式二&#xff1a;好处&#xff1a;不用定义临时变量//…

Docker Machine 简介

Docker Machine 是什么&#xff1f; Docker Machine 是 Docker 官方提供的一个工具&#xff0c;它可以帮助我们在远程的机器上安装 Docker&#xff0c;或者在虚拟机 host 上直接安装虚拟机并在虚拟机中安装 Docker。我们还可以通过 docker-machine 命令来管理这些虚拟机和 Doc…

C#基础知识详解之【字段与属性】

讲理论知识之前&#xff0c;先看一段代码&#xff1a;public class Emp {//字段private int age;//属性public int Age{get { return age; }set { age value; }} }大家可以看到上面实例代码中&#xff0c;声明了一个名为age的字段&#xff0c;还有一个名为Age的属性&#xff0…

JavaFX UI控件教程(十二)之List View

翻译自 List View 在本章中&#xff0c;您将学习如何在JavaFX应用程序中创建列表。 该ListView级代表项目的滚动列表。图11-1显示了酒店预订系统中可用住宿类型的列表。 图11-1简单列表视图 您可以通过使用该setItems方法定义其项目来填充列表。您还可以通过应用setCellFact…

MyBatis中多表查询(业务代码方式)

业务代码的方式 (实现的方式&#xff0c;书写业务逻辑的java代码实现) ------查询学生所在班级的信息 &#xff08;一对一查询&#xff09; 1、先把所有学生查询出来&#xff08;clazzno&#xff09; select* from student 2、拿着clazzno去clazz表中查询班级的信息 select * f…

ssl1010-方格取数

这道题曾经是提高组的第四题&#xff0c;但是毕竟书上有&#xff0c;所以emmmmmmmmmmmmmmmmmmmmmmmmmmmmmmm&#xff0c;QAQ。 Description   设有N*N的方格图(N<10,我们将其中的某些方格中填入正整数,而其他的方格中则放入数字0。如下图所示&#xff08;见样例&#xf…