POJ Euro Efficiency 1252
| Time Limit: 1000MS | Memory Limit: 10000K | |
| Total Submissions: 4109 | Accepted: 1754 |
Description
A student buying a 68 guilder book before January 1st could pay for
the book with one 50 guilder banknote and two 10 guilder banknotes,
receiving two guilders in change. In short:50+10+10-1-1=68. Other ways
of paying were: 50+25-5-1-1, or 100-25-5-1-1.Either way, there are
always 5 units (banknotes or coins) involved in the payment process, and
it
could not be done with less than 5 units.
Buying a 68 Euro book is easier these days: 50+20-2 = 68, so only 3
units are involved.This is no coincidence; in many other cases paying
with euros is more efficient than paying with guilders. On average the
Euro is more efficient. This has nothing to do, of course, with the
value of the Euro, but with the units chosen. The units for guilders
used to be: 1, 2.5, 5, 10, 25, 50,whereas the units for the Euro are: 1,
2, 5, 10, 20, 50.
For this problem we restrict ourselves to amounts up to 100 cents.
The Euro has coins with values 1, 2, 5, 10, 20, 50 eurocents. In paying
an arbitrary amount in the range [1, 100] eurocents, on average 2.96
coins are involved, either as payment or as change. The Euro series is
not optimal in this sense. With coins 1, 24, 34, 39, 46, 50 an amount of
68 cents can be paid using two coins.The average number of coins
involved in paying an amount in the range [1, 100] is 2.52.
Calculations with the latter series are more complex, however. That
is, mental calculations.These calculations could easily be programmed in
any mobile phone, which nearly everybody carries around nowadays.
Preparing for the future, a committee of the European Central Bank is
studying the efficiency of series of coins, to find the most efficient
series for amounts up to 100 eurocents. They need your help.
Write a program that, given a series of coins, calculates the
average and maximum number of coins needed to pay any amount up to and
including 100 cents. You may assume that both parties involved have
sufficient numbers of any coin at their disposal.
Input
first line of the input contains the number of test cases. Each test
case is described by 6 different positive integers on a single line: the
values of the coins, in ascending order. The first number is always 1.
The last number is less than 100.
Output
each test case the output is a single line containing first the average
and then the maximum number of coins involved in paying an amount in the
range [1, 100]. These values are separated by a space. As in the
example, the average should always contain two digits behind the decimal
point. The maximum is always an integer.
Sample Input
3
1 2 5 10 20 50
1 24 34 39 46 50
1 2 3 7 19 72
Sample Output
2.96 5
2.52 3
2.80 4
完全背包问题,钞票的和包括加和减,因此输入1到6个正数,可将其相反数存到7到12中
PS:G++下double输出为%.2f,C++下double输出为%.2lf
#include <iostream>
#include <cstdio>
#include <cstring>
#include <queue>
#include <cmath>
#include <map>
#include <vector>
#include <algorithm>
using namespace std;
#define lowbit(x) (x&(-x))
#define max(x,y) (x>y?x:y)
#define min(x,y) (x<y?x:y)
#define MAX 100000000000000000
#define MOD 1000000007
#define PI 3.141592653589793238462
#define INF 0x3f3f3f3f3f
#define mem(a) (memset(a,0,sizeof(a)))
typedef long long ll;
int dp[];
int a[],t;
int main()
{
scanf("%d",&t);
while(t--)
{
memset(a,,sizeof(a));
double ans=0.0;
int pos=-;
for(int i=;i<=;i++)
{
scanf("%d",&a[i]);
a[i+]=-a[i];
}
for(int i=;i<=;i++)
{
dp[i]=INF;
}
dp[]=;
for(int i=;i<=;i++)
{
if(a[i]>)
{
for(int j=a[i];j<=;j++)
{
dp[j]=min(dp[j],dp[j-a[i]]+);
}
}
else
{
for(int j=;j>=-a[i];j--)
{
dp[j+a[i]]=min(dp[j+a[i]],dp[j]+);
}
}
}
for(int i=;i<=;i++)
{
ans+=dp[i];
pos=max(pos,dp[i]);
}
printf("%.2f %d\n",ans/(100.0),pos);
}
return ;
}
POJ Euro Efficiency 1252的更多相关文章
- Euro Efficiency(完全背包)
Euro Efficiency Time Limit : 2000/1000ms (Java/Other) Memory Limit : 20000/10000K (Java/Other) Tot ...
- POJ 1252 Euro Efficiency(完全背包, 找零问题, 二次DP)
Description On January 1st 2002, The Netherlands, and several other European countries abandoned the ...
- POJ 1252 Euro Efficiency
背包 要么 BFS 意大利是说给你几个基本的货币,组成 1~100 所有货币,使用基本上的货币量以最小的. 出口 用法概率.和最大使用量. 能够BFS 有可能 . 只是记得数组开大点. 可能会出现 1 ...
- POJ 1252 Euro Efficiency(最短路 完全背包)
题意: 给定6个硬币的币值, 问组成1~100这些数最少要几个硬币, 比如给定1 2 5 10 20 50, 组成40 可以是 20 + 20, 也可以是 50 -10, 最少硬币是2个. 分析: 这 ...
- POJ 1252 Euro Efficiency ( 完全背包变形 && 物品重量为负 )
题意 : 给出 6 枚硬币的面值,然后要求求出对于 1~100 要用所给硬币凑出这 100 个面值且要求所用的硬币数都是最少的,问你最后使用硬币的平均个数以及对于单个面值所用硬币的最大数. 分析 : ...
- HOJ题目分类
各种杂题,水题,模拟,包括简单数论. 1001 A+B 1002 A+B+C 1009 Fat Cat 1010 The Angle 1011 Unix ls 1012 Decoding Task 1 ...
- POJ 1252 DP
题意:给你6个数.让你求出1~100范围内的数 最优情况下由这六个数加减几步得到. 输出平均值和最大值. 思路: 我就随便写了写,,,感觉自己的思路完全不对. 但是交上去 AC了!!! 我先当减法 不 ...
- (转)POJ题目分类
初期:一.基本算法: (1)枚举. (poj1753,poj2965) (2)贪心(poj1328,poj2109,poj2586) (3)递归和分治法. (4)递推. ...
- poj分类
初期: 一.基本算法: (1)枚举. (poj1753,poj2965) (2)贪心(poj1328,poj2109,poj2586) (3)递归和分治法. ( ...
随机推荐
- 题解 P3372 【【模板】线段树1 】(zkw)
看了一下题解里的zkw线段树,感觉讲的不是很清楚啊(可能有清楚的但是我没翻到,望大佬勿怪). 决定自己写一篇...希望大家能看明白... zkw线段树是一种优秀的非递归线段树,速度比普通线段树快两道三 ...
- MD5 加密原理(转)
MD5的全称是Message-Digest Algorithm 5(信息-摘要算法),在90年代初由MIT Laboratory for Computer Science和RSA Data Secur ...
- CVE-2011-1473 tomcat
Per the bottom of: http://tomcat.apache.org/security-7.html#Not_a_vulnerability_in_Tomcat tweak you ...
- Step by Step Do IOS Swift CoreData Simple Demo
简单介绍 这篇文章记录了在 IOS 中使用 Swift 操作 CoreData 的一些基础性内容,因为缺乏文档,基本上都是自行实验的结果.错漏不可避免,还请谅解. 部分内容借鉴了 Tim Roadle ...
- Ryu基本操作的REST API调用演示样例
import urllib2 import json def get_all_switches(): url = "http://127.0.0.1:8080/v1.0/topology/s ...
- 51nod-1310: Chandrima and XOR
[传送门:51nod-1310] 简要题意: 有一个数组S,保证里面的数是从小到大的,而且每一个数的二进制中都没有连续的1,如:1,2,4,5,8... 给出n,然后给出n个位置,求出S数组中n个位置 ...
- zzulioj--1778-- 和尚特烦恼4——有多少战斗力(gcd)
1778: 和尚特烦恼4--有多少战斗力 Time Limit: 1 Sec Memory Limit: 128 MB Submit: 259 Solved: 123 SubmitStatusWe ...
- Redis的好处知识
参考文章 http://www.cnblogs.com/wupeiqi/articles/5132791.html 使用Redis有哪些好处? () 速度快,因为数据存在内存中,类似于HashMap, ...
- BZOJ 3240 构造矩阵+矩阵快速幂
思路: ax+b cx+d 构造矩阵+矩阵快速幂 (需要加各种特判,,,,我好像加少了- ) //By SiriusRen #include <cstdio> #include <c ...
- poj2823/hdu3415 - 数据结构 单调队列
poj2823 题目链接 长度为N的数组,求宽度k的滑动窗口在数组上滑动时窗口内的最大值或最小值 如果用单调队列做,求最小值时,队列应该严格递增的.所以插入时,队尾大于等于插入值的元素都应被舍弃,因为 ...