动态规划:HDU1864-最大报销额(处理带小数的dp问题)
最大报销额
Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)
m Type_1:price_1 Type_2:price_2 ... Type_m:price_m
其中正整数 m 是这张发票上所开物品的件数,Type_i 和 price_i 是第 i 项物品的种类和价值。物品种类用一个大写英文字母表示。当N为0时,全部输入结束,相应的结果不要输出。
解题心得:
1、这个题的输入真的是很烦人,明明就是考察的一个背包问题,但是偏偏要在输入问题上为难人,感觉贼烦,但是字符串功底比较强的人还是可以比较简单的处理一下就行了 ,几个晒选的问题,单类金额超过600作废,总共金额超过1000作废,除了A,B,C三类还有其他类的作废。
2、这个题看到很多网上的人都是将小数化成整数做的,每个小数乘以一千(为了防止精度丢失),这样做的确可以,就可以化成一个简单的0-1背包问题就可以了。但是也可以就使用小数来做这道题,dp表示的是第几张票,然后将dp数组开成float就行了。详情看代码。
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std; double dp[3000050]; int main()
{
double q;
int n=1,money[35],sum;
while(scanf("%lf %d",&q,&n),n)
{
int a,b,c,l=0;
memset(dp,0,sizeof(dp));
memset(money,0,sizeof(money));
sum=(int)(q*100);//这里是没有精度损失的
for(int i=1; i<=n; i++)
{
int k,flag=1,v;
double y;
char ch;
a=b=c=0;
scanf("%d",&k);
while(k--)
{
scanf(" %c:%lf",&ch,&y);
v=(int)(y*100);
if(ch == 'A' && a + v <= 60000)
a += v;
else if(ch == 'B' && b + v <= 60000)
b += v;
else if(ch == 'C' && c + v <= 60000)
c += v;
else flag=0;
}
if(a+b+c <= 100000 && a <= 60000 && b <= 60000 && c <= 600000 && flag)
money[l++]=a+b+c;
}
int i,j;
for(i=0; i<=l; i++)
{
for(j=sum; j>=money[i]; j--)
dp[j]=max(dp[j],dp[j-money[i]]+money[i]);
}
printf("%.2f\n",dp[sum]/100.0);
}
return 0;
}
动态规划:HDU1864-最大报销额(处理带小数的dp问题)的更多相关文章
- hdu1864 最大报销额(01背包)
转载请注明出处:http://blog.csdn.net/u012860063 题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1864 Problem ...
- HDU1864 最大报销额
Description 现有一笔经费可以报销一定额度的发票.允许报销的发票类型包括买图书(A类).文具(B类).差旅(C类),要求每张发票的总额不得超过1000元,每张发票上,单项物品的价值不得超过6 ...
- 九度OJ 1025:最大报销额 (01背包、DP)
时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:4352 解决:1055 题目描述: 现有一笔经费可以报销一定额度的发票.允许报销的发票类型包括买图书(A类).文具(B类).差旅(C ...
- hdu1864最大报销额 01
先把小数乘100变成整数然后处理每个发票里面可以报销的 最后自底向上DP #include <stdio.h> #include <algorithm> #include &l ...
- hdu1864最大报销额(01背包)
http://acm.sdut.edu.cn:8080/vjudge/contest/view.action?cid=187#problem/G 该题要注意的就是每张单子A种类的总和不能大与600,同 ...
- HDU1864 最大报销额 01背包
非常裸的01背包,水题.注意控制精度 #include <iostream> #include <algorithm> #include <cstdio> #inc ...
- HDUOJ -----1864 最大报销额(动态规划)
最大报销额 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submi ...
- HDU-1864:最大报销额(浮点数01背包)
链接:HDU-4055:最大报销额 题意:现有一笔经费可以报销一定额度的发票.允许报销的发票类型包括买图书(A类).文具(B类).差旅(C类),要求每张发票的总额不得超过1000元,每张发票上,单类物 ...
- hdu 1864 最大报销额【01背包】
题目链接:https://vjudge.net/problem/HDU-1864 题目大意: 现有一笔经费可以报销一定额度的发票.允许报销的发票类型包括买图书(A类).文具(B类).差旅(C类),要求 ...
随机推荐
- asp.net后台调用前台js代码
为了通过ajax异步获取数据,我通过使用jquery的$(function{})方法,在页面加载时发送ajax请求,获取相关的数据.但是遇到了一个问题,当我发送的ajax请求需要根据传过来的URL参数 ...
- android中开启线程
其实Android启动线程和JAVA一样有两种方式,一种是直接Thread类的start方法,也就是一般写一个自己的类来继承Thread类.另外一种方式其实和这个差不多啊! 那就是Runnable接口 ...
- ActionListener 监听事件源产生的事件
用户在窗体上对组件进行一定动作,比如鼠标点击,会产生一些相应的事件,如ActionEvents,ChangeEvents,ItemEvents等,来响应用户的鼠标点击行为.通过实现ActionList ...
- servlet传值到servlet传值问题
今天在项目中遇到一个问题:中期项目自己做的新闻部分NewsPagerSortservlet传值时,正确答案如下 if(title!=""){ resp.sendRedirect(& ...
- 报错:'byte' does not name a type
这个错误是因为你在.cpp/.h中使用 byte 这个类型,把他修改成int就ok了
- repair table
mysql> show create table lixl;+-------+---------------------------------------------------------- ...
- 正则表达式---01 js篇
本文主要针对js中正则表达式的实践操作,来让大家对正则表达式有一个入门清晰的了解. 正则表达式推荐学习网址:http://www.runoob.com/regexp/regexp-tutorial.h ...
- 介绍一款渗透神器——Burp Suite
Burp Suite 是用于攻击web 应用程序的集成平台.它包含了许多工具,并为这些工具设计了许多接口,以促进加快攻击应用程序的过程.所有的工具都共享一个能处理并显示HTTP 消息,持久性,认证,代 ...
- String和string
String和string的区别 从位置讲: 1.String是.NET Framework里面的String,小写的string是C#语言中的string 2.如果把using ...
- SQL Server Profiler查询跟踪的简单使用
1.打开SQL Server Management Studio,选择工具->SQL Server Profiler,或者直接从路径:开始/程序/Microsoft SQL Server 200 ...