hdu4415 不错的想法题
题意:
一个人他有一定的血,有一些怪物,他去杀怪物,有的怪物杀死他后还可以在不费自己血的情况下任意杀死一些怪物,问你他最多杀死多少怪物,在最多杀怪前提下最好用多少血,(大体题意是这样).
思路:
首先我们把怪物分成两个集合,A一个是杀死他后可以免费杀死其他人的,B另一个是杀死他后不能免费杀死其他人的,分析下我们会发现,A集合我们只要杀死其中一个人就可以免费杀死其他人(肯定杀费血最少的),而且很有可能会攒下一些杀死B集合的机会.
其实无非两种情况,杀A集合的和不杀A集合的,如果杀选择杀A集合的那么我们肯定全杀掉,而花费的血就是A集合中血最少的那个,然后我们再把出了刚刚杀的那个以外,和B集合的所有放在一起排序称为C,杀完A集合后会剩下一下免费杀人的机会,我们用这些机会去杀C中的人,既然是免费的肯定从最大的开始杀,杀完后如果没杀没的话我们就用自己的血从小的开始在接着杀,一直杀到自己血没活着敌人没了未知,这是第一种情况,第二种情况是不杀A集合的,只杀B集合的,这种好办,直接把B排序一便,从小的开始能杀多少杀多少,最后在两种方案中选择一个最优的输出来就行了...
/*
1 只杀bi为0的 ,排序下,直接杀就行了;
2 杀bi不为0的 ,先杀死最小的那个bi不为0的,然后得到 s = b1 + b2 + b3 +++
然后在杀死其余的 n1 + n2 - 1 - s 的怪,就ok了;
*/
#include<stdio.h>
#include<algorithm>
#define N 100000 + 100
using namespace std;
typedef struct
{
int xp ,hp;
}NODE;
NODE node1[N] ,node2[N];
bool camp(NODE a ,NODE b)
{
return a.hp < b.hp;
}
int main ()
{
int t ,i ,n ,v ,n1 ,n2;
int ans1_n ,ans2_n ,ans1_hp ,ans2_hp;
int cas = 1 ,s;
scanf("%d" ,&t);
while(t--)
{
scanf("%d %d" ,&n ,&v);
n1 = n2 = s = 0;
NODE temp;
for(i = 1 ;i <= n ;i ++)
{
scanf("%d %d" ,&temp.hp ,&temp.xp);
if(temp.xp)
{
node2[++n2] = temp;
s += temp.xp;
}
else
node1[++n1] = temp;
}
ans1_n = ans1_hp = 0;
sort(node1 + 1 ,node1 + n1 + 1 ,camp);
int vv = v;
for(i = 1 ;i <= n1 ;i ++)
{
if(vv < node1[i].hp) break;
ans1_n ++;
ans1_hp += node1[i].hp;
vv -= node1[i].hp;
}
sort(node2 + 1 ,node2 + n2 + 1 ,camp);
if(v < node2[1].hp)
{
printf("Case %d: %d %d\n" ,cas ++ ,ans1_n ,ans1_hp);
continue;
}
ans2_n = 1;
ans2_hp = node2[1].hp;
v -= node2[1].hp;
if(s >= n1 + n2 - 1)
{
ans2_n = n1 + n2;
if(ans1_n > ans2_n || ans1_n == ans2_n && ans1_hp < ans2_hp)
printf("Case %d: %d %d\n" ,cas ++ ,ans1_n ,ans1_hp);
else
printf("Case %d: %d %d\n" ,cas ++ ,ans2_n ,ans2_hp);
continue;
}
for(i = 2 ;i <= n2 ;i ++)
node1[++n1] = node2[i];
sort(node1 + 1 ,node1 + n1 + 1 ,camp);
n1 -= s;
vv = v;
ans2_n += s;
for(i = 1 ;i <= n1 ;i ++)
{
if(vv < node1[i].hp) break;
vv -= node1[i].hp;
ans2_n ++;
ans2_hp += node1[i].hp;
}
if(ans1_n > ans2_n || ans1_n == ans2_n && ans1_hp < ans2_hp)
printf("Case %d: %d %d\n" ,cas ++ ,ans1_n ,ans1_hp);
else
printf("Case %d: %d %d\n" ,cas ++ ,ans2_n ,ans2_hp);
}
return 0;
}
hdu4415 不错的想法题的更多相关文章
- HDU 4972 Bisharp and Charizard 想法题
Bisharp and Charizard Time Limit: 1 Sec Memory Limit: 256 MB Description Dragon is watching NBA. He ...
- CodeForces 111B - Petya and Divisors 统计..想法题
找每个数的约数(暴力就够了...1~x^0.5)....看这约数的倍数最后是哪个数...若距离大于了y..统计++...然后将这个约数的最后倍数赋值为当前位置...好叼的想法题.... Program ...
- HDU - 5806 NanoApe Loves Sequence Ⅱ 想法题
http://acm.hdu.edu.cn/showproblem.php?pid=5806 题意:给你一个n元素序列,求第k大的数大于等于m的子序列的个数. 题解:题目要求很奇怪,很多头绪但写不出, ...
- hdu 5063 不错的小想法题(逆向处理操作)
题意: 刚开始的时候给你一个序列,长度为n,分别为a[1]=1,a[2]=2,a[3]=3,a[4]=4...a[n]=n,然后有4种操作如下: Type1: O 1 call fun1( ...
- HDU - 5969 最大的位或 想法题
http://acm.hdu.edu.cn/showproblem.php?pid=5969 (合肥)区域赛签到题...orz 题意:给你l,r,求x|y的max,x,y满足l<=x<=y ...
- hdu3006 状态压缩+位运算+hash(小想法题)
题意: 给了n个集合,问你这n个集合可以组合出多少种集合,可以自己,也可以两个,也可以三个....也可以n个集合组在一起. 思路: 是个小想法题目,要用到二进制压缩,位运算, ...
- poj1852 Ants ——想法题、水题
求最短时间和最长时间. 当两个蚂蚁相遇的时候,可以看做两个蚂蚁穿过,对结果没有影响.O(N)的复杂度 c++版: #include <cstdio> #define min(a, b) ( ...
- HDU 4193 Non-negative Partial Sums(想法题,单调队列)
HDU 4193 题意:给n个数字组成的序列(n <= 10^6).求该序列的循环同构序列中,有多少个序列的随意前i项和均大于或等于0. 思路: 这题看到数据规模认为仅仅能用最多O(nlogn) ...
- CodeForces - 156B Suspects 逻辑 线性 想法 题
题意:有1~N,n(1e5)个嫌疑人,有m个人说真话,每个人的陈述都形如X是凶手,或X不是凶手.现在给出n,m及n个陈述(以+x/-X表示)要求输出每个人说的话是true ,false or notd ...
随机推荐
- 167. 两数之和 II - 输入有序数组 + 哈希表 + 双指针
167. 两数之和 II - 输入有序数组 LeetCode_167 题目描述 方法一:暴力法(使用哈希表) class Solution { public int[] twoSum(int[] nu ...
- 381. O(1) 时间插入、删除和获取随机元素 - 允许重复
381. O(1) 时间插入.删除和获取随机元素 - 允许重复 LeetCode_381 题目详情 题解分析 代码实现 package com.walegarrett.interview; impor ...
- OpenGL中的简单坐标系初看+VAO/VBO/EBO
你好,三角形 一: 关于坐标的问题 标准化设备坐标:输入的顶点数据就应该在标准化设备坐标范围里面即:x,y,z的值都在(-1-1)之间.在这个区间之外的坐标都会被丢弃. 1.1一旦顶点数据传入顶点着色 ...
- POJ_2253 Frogger 【最短路变形】
一.题目 Frogger 二.分析 题意关键点就是那个青蛙距离.就是所有1到2的点的路径中,每条路径都可以确定一个最大值,这个最大值就是青蛙要跳的青蛙距离,然后要求这个青蛙距离最小值. 其实就是最短路 ...
- BZOJ_1503 [NOI2004]郁闷的出纳员 【Splay树】
一 题面 [NOI2004]郁闷的出纳员 二 分析 模板题. 对于全部员工的涨工资和跌工资,可以设一个变量存储起来,然后在进行删除时,利用伸展树能把结点旋转到根的特性,能够很方便的删除那些不符合值的点 ...
- 怎么理解onStart可见但不可交互
前言 今天朋友遇到一个面试题,分享给大家: onStart生命周期表示Activity可见,那为什么不能交互呢? 这个问题看似简单,但涉及到的面还是比较多的,比如Activity生命周期的理解,进程的 ...
- python-自定义一个序列
python的序列可以包含多个元素,开发者只要实现符合序列要求的特殊方法,就可以实现自己的序列 序列最重要的特征就是可以包含多个元素,序列有关的特使方法: __len__(self):该方法的返回值决 ...
- 解析库--XPath
from lxml import etree 2 text = ''' 3 <div> 4 <ul> 5 <li class = "item-0"&g ...
- Java 树结构实际应用 四(平衡二叉树/AVL树)
平衡二叉树(AVL 树) 1 看一个案例(说明二叉排序树可能的问题) 给你一个数列{1,2,3,4,5,6},要求创建一颗二叉排序树(BST), 并分析问题所在. 左边 BST 存在的问题分析: ...
- SQL注入与参数化查询
SQL注入的本质 SQL注入的实质就是通过SQL拼接字符串追加命令,导致SQL的语义发生了变化.为什么发生了改变呢? 因为没有重用以前的执行计划,而是对注入后的SQL语句重新编译,然后重新执行了语法解 ...