HDU2546题解
解题思路:先对价格排序(顺序或倒序都可以),然后,对前n-1(从1开始。排序方式为顺序)做容量为m(卡上余额)-5的01背包(背包体积和价值相等)。假设dp[i][j]表示从前i个背包中挑选体积不超过j的最大价值。
那么,m - dp[n - 1][m - 5] - price[n](价格最贵的菜)即为所求。
注意:不能先做容量为m-5的01背包,然后再从没有选择背包中挑选最大的(假设为maxV),然后输出:m - dp[n - 1][m - 5] - maxV。
为什么呢?假设除价格最大的“背包”之外的“背包”组成的集合为S, V = m - 5。
(1)如果S中所有背包的容量小于等于V, 即:sum(S) < V。则显然,m - sum(S) - maxV为所求。
(2)如果S中所有背包的容量大于V,那么,则可以在S中使用01背包算法求出容量接近于V且价值最大的若干"背包"(因为背包的容量和价值相等,所以,这若干个背包的价值也肯定接近于V),m - dp[n - 1][V]即为:打完这若干个菜后卡上余额最接近于5。所以,m - dp[n - 1][V] - maxV为所求。
代码如下:
#include<iostream> #include<cstdio> #include<cstring> #include<algorithm> using namespace std; int n, m; int food[1010]; int dp[1010]; void solve() { memset(dp, 0, sizeof(dp)); sort(food + 1, food + n + 1); int V = m - 5; for(int i = 1; i <= n - 1; i++) { for(int j = V; j >= food[i]; j--) { dp[j] = max(dp[j], dp[j - food[i]] + food[i]); } } int ans = m - dp[V]; printf("%d\n", ans - food[n]); } int main() { //freopen("DTDS.txt", "r", stdin); while(scanf("%d", &n), n != 0) { for(int i = 1; i <= n; i++)scanf("%d\n", &food[i]); scanf("%d", &m); if(m < 5)printf("%d\n", m); else solve(); } return 0; }
HDU2546题解的更多相关文章
- 2016 华南师大ACM校赛 SCNUCPC 非官方题解
我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...
- noip2016十连测题解
以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...
- BZOJ-2561-最小生成树 题解(最小割)
2561: 最小生成树(题解) Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1628 Solved: 786 传送门:http://www.lyd ...
- Codeforces Round #353 (Div. 2) ABCDE 题解 python
Problems # Name A Infinite Sequence standard input/output 1 s, 256 MB x3509 B Restoring P ...
- 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解
题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...
- 2016ACM青岛区域赛题解
A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Jav ...
- poj1399 hoj1037 Direct Visibility 题解 (宽搜)
http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...
- 网络流n题 题解
学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...
- CF100965C题解..
求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...
随机推荐
- console 代理
window.log = function(){ if(!window.console ){ return; } var arr = [].slice.call(arguments); arr.uns ...
- c# DataTable行转列
/// <summary> /// datatable行转列 /// </summary> /// <param name="dtSrc">来源 ...
- Python中方法的缺省参数问题分析
引言: 在Python中可以缺省给方法制定缺省值,但是这个缺省值在某些情况下确是和我们预期不太一致的-... 这个诡异的问题,曾经困然了我几天时间,才最终定位出来-.. 测试代码 from datet ...
- [置顶]
完美解决Android Studio 运行时出现的警告信息?
今天群友看到他说运行的时候报下面的错,我记得我之前导入百度地图也是遇到过,运行的时候一堆警告信息,然后编译失败等的,特别郁闷,其实后来在网上查了下,原来是很多第三方里面加个混淆,然后你有找不到那些方法 ...
- HDU 1374
http://acm.hdu.edu.cn/showproblem.php?pid=1374 已知三点坐标,求三点确定的圆的周长 #include <iostream> #include ...
- Linux运维-Rsync+Inotify
Rsync+Inotify Rsync:linux系统下的数据镜像备份工具.使用快速增量备份工具Remote Sync可以远程同步,支持本地复制,或者与其他SSH.rsync主机同步. 特性: 可 ...
- Buildroot 使用默认配置
/******************************************************************************** * Buildroot 使用默认配置 ...
- 用pip安装python 模块OpenSSL
windows下 1.配置好pip命令 下载安装 pip‑1.5.6.win‑amd64‑py2.7.exeor pip‑1.5.6.win32‑py2.7.exe 装好在C:\Python27\Sc ...
- 细说C语言的优先级和结合性
Table0. 为什么要掌握优先级1. 优先级1.1 优先级图表1.2 运算符实例1.3 优先级顺口溜2. 结合性3. 参考资料 写代码的时候,常会翻看的一个表就是“c语言运算符优先级表”.c的运算符 ...
- linux自学(九)之开始centos学习,安装数据库MariaDB
上一篇:linux自学(八)之开始centos学习,安装tomcat 数据库我们不安装mysql,我网上看了好多资料发现mysql安装比较麻烦,我们这里安装同一个父亲的产品MariaDB.驱动,端口等 ...