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 & ...
随机推荐
- L167
- linux下c语言源码编译
一.源码编译过程 源码 ---> 预处理 ---> 编译 ---> 汇编 ---> 链接 --->执行 我们可以把它分为三部分来完成: ./configure ...
- spring之httpclient doget请求
/** * @param url 请求地址 * @param jsonString 加密后的字符串 * @return * @throws ClientP ...
- vue和react
1. 数据渲染 vue是使用template模板进行渲染,react使用的是jsx语法,对组件进行渲染 vue模板中使用{{ this.data }} 双括号包着变量,代表变量表示的值.外面那层表示需 ...
- Android 仿微信朋友圈查看
项目要做一个类似于这样的功能,就做了. 项目下载地址:http://download.csdn.net/detail/u014608640/9917626 一,看下效果: 二.activity类 pu ...
- EasyDSS RTMP流媒体服务器videojs flash播放RTMP/HLS提示错误的解决方案
本文转自EasyDSS团队成员StarIT的博客:http://blog.csdn.net/staritstarit/article/details/73692715 问题 在博客<EasyDS ...
- LNMP架构基础搭建
LNMP架构+wordpress博客 环境: centos6.7 2.6.32-573.el6.x86_64 nginx-1.6.3 mysql-5.5.49 php-5.3.27 wordpress ...
- linux下端口被占用
1.查看端口 netstat -ano 参数含义: -a, --all 显示监听或非监听状态的接口 Show both listening and non-listening (for TCP t ...
- Python源码分析(一)
最近想学习下Python的源码,希望写个系列博客,记录的同时督促自己学习. Python源码目录 从Python.org中下载源代码压缩包并解压,我下载的是Python2.7.12,解压后: 对于主要 ...
- 百度的富文本编辑器UEDITOR
还是百度的ueditor 比较好用,文件导入后,基本不用配置就可以直接使用图片,文件上传等功能. CKeditor要注意的地方太多了 .但是相对ckeditor 样式比较好看.