【hdoj_2570】迷障
题目:http://acm.hdu.edu.cn/showproblem.php?pid=2570
思路:贪心法.要求在浓度不超标的情况下,解药的最大体积.由于体积相同,可以先对浓度排序,然后从浓度小的药水开始配制,直到超标的前一次,就可以求出最大体积和对应的不超标的最大浓度.
注意:根据题目要求,每种药液,要用就得全用,要么不用,即【不能分割】.
C++代码如下:
#include<iostream>
#include<algorithm>
#include<iomanip>
using namespace std;/*
*由于所有的药水体积相同,所以浓度就与体积无关了,例如两个浓度分别为c1和c2的药水
*等体积混合,所得药液的浓度就是二者均值,三个浓度不同的药水等体积混合,浓度就是三者均值.
*所以,只有在最后计算解药的最大体积的时候需要用到这个输入的体积V的值.
*/int main(){ int C; cin >> C;//测试组数 while(C--) {
int n,V,W;//配药的种类n,每种配药的的体积V,解药允许的最大浓度W
cin >> n >> V >> W; int *p = new int[n];
for(int i=0;i<n;i++) cin >> p[i];//输入每种配药的浓度
sort(p,p+n);//按照浓度从小到大排序 double sum = 0;//记录了"浓度"(浓度*100的值*目前所选择的药液种类数)
int k;//k的最终值,记录了最终所选择了几种药液 for(k=0;k<n;k++)
{ if(sum+p[k]<=(k+1)*W)//假设把第k中药液用上,如果"浓度"不超标
sum += p[k];//那就把第k中药液用上 else//如果超标了,那如果用上后面浓度更大的药液更超标
break;//所以退出
} //k值记录了用了几种药液,而每种药液的体积相同
if(k==0) cout << "0 0.00" << endl;
else//输出的第一个量为最终解药的体积,是个整数;第二个量为浓度(真正的浓度)
cout << k*V << " " << setprecision(2) << fixed << sum / (k*100) << endl; } return 0;}上述代码直接提交有错误提示(代码长度不符合要求),删去所有注释提交通过.
小结:
1.setprecision用于控制输出几位小数,它加载了#include<iomanip>头文件.它的用法如下:
#include<iostream>
#include<iomanip>
using namespace std; int main()
{
cout << 1.2345 << endl;
cout << setprecision(2) << fixed << 1.2345 << endl;//对后面的double类型数据有用
cout << 1.2345 << endl;//同样是double类型数据
cout << 12345 << endl;//但是,对整型数据不起作用 return 0;
}运行结果如下图:
2.题目的三个测试数据的药水体积均为V=100,可以改为其他数据进行测试,以免和【百分之xxx】中的100混淆.
【hdoj_2570】迷障的更多相关文章
- hdu_2570 迷障 贪心
迷瘴 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submissi ...
- 初期测评 E 迷障
https://vjudge.net/contest/240302#problem/E 通过悬崖的yifenfei,又面临着幽谷的考验—— 幽谷周围瘴气弥漫,静的可怕,隐约可见地上堆满了骷髅.由于此处 ...
- 【Origin】 画道
-夏之时,晚归途中,观云,感雨,识迷障,题以记之. 原道是东边日出西边雨, 却原来乌云蔽日雨不息; 只不过光芒也破云边洒, 可还是满地泥泞水花起. --作于二零一六年七月十一日
- 【JavsScript】转载---如何成为优秀的前端
题记 做好前端 关于离职 如何成为优秀的前端 书籍推荐 博客推荐 源码阅读 去面试 14年计划 招聘信息 题记 四月前,低迷.失志踌躇不前形容自己再好不过,中途来了一次彻底的醒悟,于是我发现自己变得勤 ...
- width:100vh有感而发
在看一个网页的代码是看到 width:100vh 纳尼...这这我怎么没有见过,这是个什么属性,随之有看到 min-height:calc(100vh + 51px);这尼玛又是怎么用的.... 感 ...
- 十三篇系列:king转折点,wooga瓶颈,supercell营收结构
转自:http://gamerboom.com/archives/95125 十三篇系列:king的历史转折点,wooga的瓶颈,supercell的营收结构 第一篇 这句话In other word ...
- LeakCanary 原理浅析
前言 提到Java语言的特点,无论是教科书还是程序员一般都会罗列出面向对象.可移植性及安全等特点.但如果你是一位刚从C/C++转到Java的程序员,对Java语言的特性除了面向对象之外,最外直接的应当 ...
- 混乱中的ICO平台,会不会是下一个P2P的重灾区?
当众多巨头和创业者还在为共享打车.共享单车.VR.IP化.互联网金融沉迷时,一种全新的"众筹"正在造就一个又一个暴富神话.其名为ICO,即首次代币众筹,一般指区块链初创项目在众筹平 ...
- Java中文字符处理的四大迷题
虽然计算机对英文字符的支持非常不错,我们也恨不得写的程序只会处理英文的数据,但是昨为中国人,无可避免地要处理一些中文字符.当很简单的一件事情,遇到了中文,一切就不同了!本文就会讲述实际生产环境中遇到的 ...
随机推荐
- POI 2018.10.20
[POI2005]BANK-Cash Dispenser 有多少个4位字符串是所有操作序列的子串. 10^4枚举字符串.暴力判断会TLE 发现,我们就是在每个操作序列中不断找第一个出现的c字符. 预处 ...
- BZOJ1912 APIO2010 洛谷P3629 巡逻
Description: 在一个地区中有 n 个村庄,编号为 1, 2, ..., n.有 n – 1 条道路连接着这些村 庄,每条道路刚好连接两个村庄,从任何一个村庄,都可以通过这些道路到达其 他任 ...
- poco入门
源码按照poco.然后看README,进行安装. ./configure make make install #include "Poco/ActiveMethod.h" #inc ...
- C# 后台获取请求来源、文件下载
文件流下载文件 void BigFileDownload() { try { string FileName = "测试.docx"; string filePath = Page ...
- Hive、Pig、HBase的关系与区别
欢迎关注大数据和人工智能技术文章发布的微信公众号:清研学堂,在这里你可以学到夜白(作者笔名)精心整理的笔记,让我们每天进步一点点,让优秀成为一种习惯! Pig 一种操作hadoop的轻量级脚本语言,最 ...
- 图论:最短路-Dijkstra
Dijkstra+堆优化具有稳定的时间复杂度,在一些数据范围要求比较严格(准确来说是图比较苛刻)的时候能够保证稳定的时间复杂度 但是Dijkstra不能够解决负边权的问题,所以在使用的时候一定要仔细读 ...
- 【C++对象模型】第五章 构造、解构、拷贝 语意学
1.构造语义学 C++的构造函数可能内带大量的隐藏码,因为编译器会扩充每一个构造函数,扩充程度视 class 的继承体系而定.一般而言编译器所做的扩充操作大约如下: 所有虚基类成员构造函数必须被调用, ...
- WPF 添加Adminstrator 权限
在WPF应用开发中,需要WPF操作后台注册的Windows Service,可是WIX打包的安装程序不具备赋予WPF App默认管理员权限. 因此,需要我们手工在WPF项目中添加管理员权限: 1.右击 ...
- 【洛谷 P4008】 [NOI2003]文本编辑器 (Splay)
题目链接 \(Splay\)先练到这吧(好像还有道毒瘤的维护数列诶,算了吧) 记录下光标的编号,维护就是\(Splay\)基操了. 另外数据有坑,数据是\(Windows\)下生成了,回车是'\n\r ...
- javascript中数据属性与访问器属性
1.数据属性 Configurable:true|false,表示能否通过delete将属性删除,默认为true.当把属性的Configurable设置为false后,该属性不能通过delete删除, ...