当前位置: 首页 > 编程日记 > 正文

uestc 1012 饭卡

饭卡(card)

Time Limit: 1000 ms Memory Limit: 65535 kB Solved: 253 Tried: 2169

Submit

Status

Best Solution

Back

Description

电子科大本部食堂的饭卡有一种很诡异的设计,即在购买之前判断余额。如果购买一个商品之前,卡上的剩余金额大于或等于5元,就一定可以购买成功(即使购买 后卡上余额为负),否则无法购买(即使金额足够)。所以大家都希望尽量使卡上的余额最少。
某天,食堂中有n种菜出售,每种菜可购买一次。已知每种菜的价格以及卡上的余额,问最少可使卡上的余额为多少。

Input

多组数据。对于每组数据:
第一行为正整数n,表示菜的数量。n<=1000。
第二行包括n个正整数,表示每种菜的价格。价格不超过50。
第三行包括一个正整数m,表示卡上的余额。m<=1000。

n=0表示数据结束。

Output

对于每组输入,输出一行,包含一个整数,表示卡上可能的最小余额。

Sample Input

1
50
5
10
1 2 3 2 1 1 2 3 2 1
50
0

Sample Output

-45
32

// f[i][j] :前i个物品能否把空间j填满
// f[i][j]=f[i][j]==1?f[i][j]:f[i-1][j-r[i]]
// f[i][0]=1;解为 小于等于m-5的空间中 可以被填满的最大值
// 根据0,1 背包 这里可以利用滚动数组 所以将f降到1维
// 把最大值单独提取出来、、剩余用来做0,1背包 为什么这样做是对的
// 证明 : 假设 将最大值Max用来求0,1 背包, 则设比Max小的数在集合 s{..}中
// 最后打的菜价为 P 则 sigma S{..}+Max+P 就是所花的钱。 m-sigma S{..}-Max-P就是饭卡最后剩下的钱
// 若用P来代替 Max, Max代替P 则结果是一样的, 其中还有可能 P+T{..}=Max 这样的话 剩余的钱就是
//m-sigma S{..}-Max-P-sigma T{..} 明显还更小、所以将最大的值用来当做最后一个菜来打肯定正确
#include <iostream> #include <stdio.h> #include <algorithm> #include <vector> #include <queue> #include <stack> #include <string.h> using namespace std; int r[1010]; int n,m; int f[1010]; int main() {while(scanf("%d",&n),n){int i,j;for(i=0;i<n;i++)scanf("%d",&r[i]);sort(r,r+n);scanf("%d",&m);if(m<5) { printf("%d\n",m);continue;}memset(f,0,sizeof(f));for(i=0;i<n-1;i++)for(j=m-5;j>=r[i];j--)if(j==r[i]) f[j]=1;elsef[j]=f[j]|f[j-r[i]];for(i=m-5;i>0;i--)if(f[i])break;printf("%d\n",m-r[n-1]-i);}return 0; }

转载于:https://www.cnblogs.com/372465774y/archive/2013/04/22/3036124.html

相关文章:

wps临时文件不自动删除_win10系统下wps残留文件无法删除如何解决

一位用户反馈自己在win10系统电脑中卸载金山WPS办公软件时&#xff0c;发现根本无法将wps残留的文件夹删除&#xff0c;在删除的时候提示“操作无法完成&#xff0c;因为其中的文件夹或文件已在另一程序打开 请关闭该文件夹文件重试”&#xff0c;这该怎么办呢&#xff1f;接下…

WEB登录H3C模拟器

思路&#xff1a;先将路由器与本地网卡绑定&#xff0c;然后将本地网卡与路由器接口ip设置在同一网段&#xff0c;在路由器上建立本地用户&#xff0c;最后登录就OK了。 1、查看本机网卡的序列号&#xff0c;在CMD里输入systeminfo&#xff0c;输出的最下…

ArcMap 通过DEM获取高程值

第一种方法&#xff1a;Extract values to Points工具&#xff0c;这个网上的资料比较多&#xff0c;就不介绍了。 第二种方法&#xff1a;Interpolate Shape工具 直接用Arc Toolbox->3D Analyst Tools->功能性表面->Interpolate Shape工具就行&#xff0c;可以将DEM的…

Linux进程描述符task_struct结构体简析

进程是处于执行期的程序以及它所管理的资源&#xff08;如打开的文件、挂起的信号、进程状态、地址空间等等&#xff09;的总称 Linux内核通过一个被称为进程描述符的task_struct结构体来管理进程&#xff0c;这个结构体包含了一个进程所需的所有信息。它定义在include/linux/…

hdu 1312 Red and Black 解题报告

题目链接&#xff1a;http://acm.hdu.edu.cn/showproblem.php?pid1312 第二条深搜&#xff0c;题目并不难&#xff0c;但是做了我好久好久&#xff0c;由于一个细节&#xff0c;让我赌上了一个晚上的时间。 题目大意&#xff1a;从图中的标记开始&#xff0c;向四个相邻的方向…

easyexcel怎么设置表头宽度_easyexcel 自动设置列宽

com.alibabaeasyexcel2.1.4导出controller层代码RequestMapping("/download")public void download(HttpServletResponse response) throws IOException {response.setContentType("application/vnd.ms-excel");response.setCharacterEncoding("utf-8…

php ImageMagick扩展

linux下安装php ImageMagick扩展模块下载ImageMagick源码包&#xff1a;#wget ftp://ftp.u-aizu.ac.jp/pub/graphics/p_w_picpath/ImageMagick/p_w_picpathmagick.org/ImageMagick.tar.gz 编译安装&#xff1a;#tar -zxvf ImageMagick.tar.gz #cd ImageMagick-xxxx-0#./confi…

调用浏览器的打印方法打印页面内容

2018-08-30 直接调用浏览器的打印方法 1、打印按钮 <a href"#" target"_self" οnclick"printme()">打印</a> 2、js //打印function printme() {$.messager.confirm(确认, 确认打印&#xff1f;, function (r) {if (r) {document.bo…

jsp中九大内置对象

内置组件 JSP共有以下9种基本内置组件&#xff08;可与ASP的6种内部组件相对应&#xff09;&#xff1a;1.request对象 客户端的请求信息被封装在request对象中&#xff0c;通过它才能了解到客户的需求&#xff0c;然后做出响应。它是HttpServletRequest类的实例。序号 方 法 说…

python数组越界_python 整数越界问题详解

python 内部自带大整数运算能力&#xff0c;整数运算不会溢出&#xff0c;只要内存足够&#xff0c;就oK下面的例子演示了两个32位整数加法的情况(通过位运算实现)&#xff0c;为了模拟溢出的效果&#xff0c;必须人工的进行位运算&#xff0c;~运算符除了求反&#xff0c;还是…

Linux虚拟机连不上网

问题&#xff1a;我们在使用Linux虚拟机的时候经常会出现各种各样的问题&#xff0c;其中的一个问题就是Linux虚拟机连不上网&#xff0c;这是我最近经常遇到的问题&#xff0c;下面提供一种方法解决这个问题 Linux网络设置 打开虚拟机依次单击【System】–>【Preferences】…

企业如何利用新闻类软文营销策划

新闻软文营销对企业的推广有哪些优势呢? 一、首先让客户有机会直接在门户网上相关频道看到关于企业产品的新闻&#xff0c;产生直接的点击或者评论&#xff0c;带来直接客户。 二、当潜在客户运用百度等搜索引擎搜索企业的公司名或者产品的关键词&#xff0c;那么就会在一个页…

WPF XAML 资源样式模板属性存放位置

WPF XAML 资源样式模板属性存放位置 原文:WPF XAML 资源样式模板属性存放位置WPF的XAML 资源申明 类似HTML。 整体来说分3种1.行类资源样式属性 1.1 行内属性 <Button Content"按钮" Foreground"White" FontSize"30"></Button>1.2 行…

SQL Server 数据库备份

SQL Server 数据库备份 原文 http://www.cnblogs.com/ynbt/archive/2013/04/04/2999642.html 备份数据库是指对数据库或事务日志进行复制&#xff0c;当系统、磁盘或数据库文件损坏时&#xff0c;可以使用备份文件进行恢复&#xff0c;防止数据丢失。 SQL Server数据库备份支持…

Linux下修改PATH环境变量

Linux下有很多环境变量&#xff0c;PATH就是其中的一种 PATH 可执行文件的搜索路径。ls命令也是一个程序,执行它不需要提供完整的路径名/bin/ls,然 而通常我们执行当前目录下的程序a.out却需要提供完整的路径名./a.out,这是因为PATH 环 境变量的值里面包含了ls命令所在的目…

vscode 终端 进入node_安装了Node.js 从VScode 使用node -v 和 npm -v等命令却无效

前言最近写TypeScript需要安装、配置Node.js环境&#xff0c;楼主是使用的安装包所以环境变量都是自动就配好了(如果是下载的zip压缩包解压后要自己配置到系统环境变量中)。打开系统终端敲入命令 node -v 和 npm -v 也都有显示对应的软件包版本号&#xff0c;但是在VScode(Vis…

display:inline-block的妙用!!列表布局!!

如下图&#xff1a;像这种列表布局我们一般用 float:left; 设置宽度和高度就OK了。 但是&#xff0c;如果高度不同或者文字字数不同呢&#xff0c;再用float:left;布局就全乱了。如下图&#xff1a; 现在&#xff0c;我们可以利用display:inline-block;完美的解决这个问题。如下…

gitlab解决一些问题

一.修改gitlab端口&#xff1a; 打开/etc/gitlab/gitlab.rb文件&#xff0c;修改以下几点&#xff1a; external_url "http://192.168.58.62:9999"unicorn[listen] localhostunicorn[port] 9999 然后 #gitlab-ctl stop #gitlab-ctl reconfugure #gitlab-ctl start …

Linux下控制环境变量

查看环境变量 查看某一环境变量&#xff1a;比如我们需要查看HOME这个环境变量&#xff0c;我们可以在shell下直接输入echo $HOME 我们可以把所有的环境变量和环境变量的值都打印出来 打印环境变量 libc中定义的全局变量environ指向环境变量表,environ没有包含在任何头文件中,…

研究性能测试工具之systemtap入门指南(四)

运行脚本[rootBL480-64 jinyz]#stap topexe.stp输出结果&#xff1a; SYSCALL COUNT find 101910 oracle 1562 modclusterd 1184 pcscd 535 clustat …

linux 编译mqtt静态库_编译MQTT C++ Client

nmake -f ms\nt.mak(这是静态库,动态库是ntdll.mak)nmake -f ms\nt.mak test(测试命令,如果成功则最后显示“passed all tests”字样)nmake -f ms\nt.mak install 成功则会在C:\openss\win64目录下生成bin、include、lib、ssl四个文件夹如果需要编译动态库&#xff0c;nm…

ubuntu 目录结构

转载于:https://www.cnblogs.com/perfy/archive/2012/07/08/2581854.html

pandas 读csv文件 TypeError: Empty 'DataFrame': no numeric data to plot

简单的代码&#xff0c;利用pandas模块读csv数据文件&#xff0c;这里有两种方式&#xff0c;一种是被新版本pandas遗弃的Series.from_csv&#xff1b;另一种就是pandas.read_csv 先说一下问题这个问题就是在读csv文件时&#xff0c;默认的数据是object类型&#xff0c;因而没有…

Linux的僵尸进程

僵尸进程的简单理解 linux中有几种进程状态&#xff0c;其中有一种特殊就是僵尸进程&#xff0c;个人理解是可以这样理解&#xff0c;就是我们 的子进程已经退出了&#xff0c;但是子进程退出了之后无家可归&#xff0c;就是一个飘移的孤魂野鬼一样&#xff0c;所以形象的取名字…

class function或class procedure是什么意思

类函数\类过程. 它们是直接操作在类上面(没有实例化的对象) 下面是Delphi Help 的描述 A class method is a method (other than a constructor) that operates on classes instead of objects. The definition of a class method must begin with the res…

pythonshell画图_Python Shell下使用matplotlib

Python Shell下使用matplotlibCreated Monday 10 December 2012matplotlib默认是延迟绘图直到脚本结束&#xff0c;因为绘图是一个高代价的操作。所以可能不想每次每个属性的改变就更新绘图&#xff0c;只有所有的属性都改变了才更新。但是&#xff0c;当在python shell上工作时…

大地坐标的概念 大地坐标系的举例和说明分类

大地坐标大地测量中以参考椭球面为基准面的坐标。地面点P的位置用大地经度L、大地纬度B和大地高H表示。当点在参考椭球面上时&#xff0c;仅用大地经度和大地纬度表示。大地经度是通过该点的大地子午面与起始大地子午面之间的夹角&#xff0c;大地纬度是通过该点的法线与赤道面…

C# 在用户控件中添加自定义事件

/// <summary> /// 用户控件 /// </summary> public partial class UCMyControl : UserControl {//定义委托//EventArgs 可以自己定义参数的类型&#xff0c;一般情况下定义为(object sender&#xff0c;EventArgs e)public delegate void SelectedValueChanged(o…

标准h5的定位_H5中的定位

这次给大家带来H5中的定位&#xff0c;H5中定位的注意事项有哪些&#xff0c;下面就是实战案例&#xff0c;一起来看一下。一.定位流分类1.1相对定位1.2绝对定位1.3固定定位1.4静态定位二.什么是相对定位?相对定位就是相对于自己以前在标准流中的位置来移动position: relative…

数据库开发基本操作-关于sql server 2005 未开放1433端口的问题

有些sql server 2005在安装过程中&#xff0c;可能将SQL server 服务的端口配置成了动态端口&#xff0c;没有使用默认的1433端口&#xff0c;从而导致了sql server 2005 的服务启动了&#xff0c;但是却没有开启1433端口。解决办法就是取消动态端口&#xff0c;并将端口改成14…