ACM学习历程—HDU4415 Assassin’s Creed(贪心)
Problem Description
Ezio Auditore is a great master as an assassin. Now he has prowled in the enemies’ base successfully. He finds that the only weapon he can use is his cuff sword and the sword has durability m. There are n enemies he wants to kill and killing each enemy needs Ai durability. Every time Ezio kills an enemy he can use the enemy’s sword to kill any other Bi enemies without wasting his cuff sword’s durability. Then the enemy’s sword will break. As a master, Ezio always want to do things perfectly. He decides to kill as many enemies as he can using the minimum durability cost.
Input
The first line contains an integer T, the number of test cases.
For each test case:
The first line contains two integers, above mentioned n and m
(1<=n<=10^5, 1<=m<=10^9).
Next n lines, each line contains two integers Ai, Bi. (0<=Ai<=10^9,
0<=Bi<=10).
Output
For each case, output "Case X: "
(X is the case number starting from 1) followed by the number of the enemies
Ezio can kill and the minimum durability cost.
Sample
Input
2
3 5
4 1
5 1
7 7
2 1
2 2
4 0
Sample
Output
Case 1:
3 4
Case 2: 0 0
题目大意是用m点耐久度去杀人,杀死一个人需要Ai耐久度,但是可以额外再杀死Bi个人。
题目要求的首先是杀人最多,其次是消耗耐久度最少。
首先会想到对人进行分类,一类是B为0的,一类是B不为0的。
因为杀死一个B不为0的,一定能杀死所有B不为0的,而且还能再额外杀死B为0的。
于是就先分出第一种情况:不杀B不为0的人;
这样就是对B为0的人进行贪心,优先杀消耗耐久度最小的即可。
考虑第二种情况:杀死至少一个B不为0的人。
那么首先前提自然是保证能杀死B不为0的人里面消耗耐久度最少的。
然后就可以杀死所有B不为0的人。而且还能再额外杀死B为0的。
最后就是用剩余耐久度去杀死剩下的B为0的人。
但是这样会出现一种情况。就是虽然B不为0的人,可以自动杀死,但是如果我手动杀死一个B不为0的人,可以多出一个名额杀死一个B为0的人。但是也许这样我会消耗更低的耐久度去手动杀死一个人。
于是就发现,肯定可以杀死所有B不为0的人,但是可以优先手动杀死耐久度小的。
得出结论:杀死第一个耐久度最小的B不为0的人后,我便按照耐久度从小到大手动杀人。
此处还要注意的是,我依次杀人后,如果剩下的人都能被自动杀死,我便不需要再手动杀死人了。
最后就是两种情况取最值了。
代码:
#include <iostream>
#include <cstdio>
#include <cstring>
#include <cmath>
#include <algorithm>
#include <set>
#include <utility>
#include <queue>
#include <vector>
#define LL long long using namespace std; typedef pair<int, int> pii;
const int maxN = 1e5+;
int n, m;
struct node
{
int need;
int kill;
}p[][maxN];
int top[];
int can; bool cmpNeedLest(node x, node y)
{
return x.need < y.need;
} void input()
{
scanf("%d%d", &n, &m);
can = ;
top[] = top[] = ;
int need, kill;
for (int i = ; i < n; ++i)
{
scanf("%d%d", &need, &kill);
if (kill == )
{
p[][top[]].need = need;
p[][top[]].kill = ;
top[]++;
}
else
{
p[][top[]].need = need;
p[][top[]].kill = kill;
top[]++;
can += kill;
}
}
sort(p[], p[]+top[], cmpNeedLest);
sort(p[], p[]+top[], cmpNeedLest);
} pii workOne()
{
//p->p+top;
int num = , rest = m;
for (int i = ; i < top[]; ++i)
{
if (rest >= p[][i].need)
{
num++;
rest -= p[][i].need;
}
else
break;
}
return pii(num, m-rest);
} pii workTwo()
{
int rest = m, num = ;
int from[];
from[] = from[] = ;
if (top[] == || rest < p[][].need)
return pii(, );
rest -= p[][].need;
from[]++;
bool flag;
for (;;)
{
if (n-(from[]+from[]) <= can)
break;
flag = false;
if (from[] < top[] && p[][from[]].need > p[][from[]].need)
{
if (rest >= p[][from[]].need)
{
flag = true;
rest -= p[][from[]].need;
from[]++;
num++;
}
}
else if (from[] < top[])
{
if (rest >= p[][from[]].need)
{
flag = true;
rest -= p[][from[]].need;
from[]++;
num++;
}
}
if (!flag)
break;
}
return pii(min(from[]+from[]+can, n), m-rest);
} void work()
{
pii one, two;
one = workOne();
two = workTwo();
if (one.first > two.first)
printf("%d %d\n", one.first, one.second);
else if (one.first == two.first)
printf("%d %d\n", one.first, min(one.second, two.second));
else
printf("%d %d\n", two.first, two.second);
} int main()
{
//freopen("test.in", "r", stdin);
int T;
scanf("%d", &T);
for (int times = ; times <= T; ++times)
{
input();
printf("Case %d: ", times);
work();
}
return ;
}
ACM学习历程—HDU4415 Assassin’s Creed(贪心)的更多相关文章
- HDU-4415 Assassin’s Creed 贪心
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4415 用贪心来解,开始分为两个集合的方法错了,没有考虑之间的相互影响,正确的姿势应该是这样的,分两种情 ...
- ACM学习历程——NOJ1113 Game I(贪心 || 线段树)
Description 尼克发明了这样一个游戏:在一个坐标轴上,有一些圆,这些圆的圆心都在x轴上,现在给定一个x轴上的点,保证该点没有在这些圆内(以及圆上),尼克可以以这个点为圆心做任意大小的圆,他想 ...
- ACM学习历程—HDU5422 Rikka with Graph(贪心)
Problem Description As we know, Rikka is poor at math. Yuta is worrying about this situation, so he ...
- ACM学习历程—CSU 1216 异或最大值(xor && 贪心 && 字典树)
题目链接:http://acm.csu.edu.cn/OnlineJudge/problem.php?id=1216 题目大意是给了n个数,然后取出两个数,使得xor值最大. 首先暴力枚举是C(n, ...
- ACM学习历程—HihoCoder1309任务分配(排序 && 贪心)
http://hihocoder.com/problemset/problem/1309 题目大意是给定n个任务的起始时间,求问最少需要多少台机器. 有一个贪心的策略就是,如果说对于一个任务结束,必然 ...
- ACM学习历程—FZU 2144 Shooting Game(计算几何 && 贪心 && 排序)
Description Fat brother and Maze are playing a kind of special (hentai) game in the playground. (May ...
- ACM学习历程—HDU 4726 Kia's Calculation( 贪心&&计数排序)
DescriptionDoctor Ghee is teaching Kia how to calculate the sum of two integers. But Kia is so carel ...
- ACM学习历程——HDU 5014 Number Sequence (贪心)(2014西安网赛)
Description There is a special number sequence which has n+1 integers. For each number in sequence, ...
- ACM学习历程——POJ 1700 Crossing River(贪心)
Description A group of N people wishes to go across a river with only one boat, which can at most ca ...
随机推荐
- Cocos2d-x中使用第三方so库
项目中假设使用到第三方的SDK,大多数是以.so动态共享库的文件打包给我们使用.怎样使用他们,见以下分析. 1.获得库文件 假如我们得到的库文件是libxxx.so(注:关于.so文件的命名方式,可百 ...
- Netty实现java多线程Post请求解析(Map参数类型)—SKY
netty解析Post的键值对 解析时必须加上一个方法,ch.pipeline().addLast(new HttpObjectAggregator(2048)); 放在自己的Handel前面. ht ...
- maven assembly 配置详解
Maven Assembly插件介绍 博客分类: 项目构建 你是否想要创建一个包含脚本.配置文件以及所有运行时所依赖的元素(jar)Assembly插件能帮你构建一个完整的发布包. Assembl ...
- 九度OJ 1335:闯迷宫 (BFS)
时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:1782 解决:483 题目描述: sun所在学校每年都要举行电脑节,今年电脑节有一个新的趣味比赛项目叫做闯迷宫. sun的室友在帮电脑节设计 ...
- nginx + uWSGI 为 django 提供高并发
django 的并发能力真的是令人担忧,这里就使用 nginx + uwsgi 提供高并发 nginx 的并发能力超高,单台并发能力过万(这个也不是绝对),在纯静态的 web 服务中更是突出其优越的地 ...
- LOJ#10117. 「一本通 4.1 练习 2」简单题
LOJ#10117. 「一本通 4.1 练习 2」简单题 题目描述 题目来源:$CQOI 2006$ 有一个$n$个元素的数组,每个元素初始均为$0$.有$m$条指令,要么让其中一段连续序列数字反转— ...
- 计算机网络协议层次(转发:http://blog.csdn.net/gavin_john/article/details/53186570)
计算机网络学习的核心内容就是网络协议的学习.网络协议是为计算机网络中进行数据交换而建立的规则.标准或者说是约定的集合.计算机网络协议同我们的语言一样,多种多样. 为了给网络协议的设计提供一个结构,网络 ...
- Data Structure Binary Search Tree: Find k-th smallest element in BST (Order Statistics in BST)
http://www.geeksforgeeks.org/find-k-th-smallest-element-in-bst-order-statistics-in-bst/ #include < ...
- nodejs模块之http&&url
我们使用nodejs中的http模块来进行网络操作 一.什么是HTTP协议: 超文本传输协议(HyperText Transfer Protocol)HTTP假定其下层协议提供可靠传输. 因此,任何能 ...
- python3 内置常用函数系列一
python3 内置了一系列的常用函数, python英文官方文档详细说明:点击查看, 为了方便查看,将内置常用的函数的记录一下来. Python3版本所有的内置函数: 1.abs() print(a ...