题意:给出n把枪和m个怪。每把枪有一个攻击力,每一个怪有一个防御力。假设某把枪的攻击力不小于某个怪的防御力则能将怪秒杀,否则无法杀死。一把枪最多仅仅能杀一个怪,不能用多把枪杀同一个怪。每杀一次怪能够得到枪的攻击力减去怪的防御力的的分数。

求得分的最大值。

贪心。首先我们考虑这样一种情况:用攻击力为A的枪杀防御力为a的怪,攻击力为B的枪杀防御力为b的怪。则得分为A - a + B - b。

最好还是设A ≤ B,则有a ≤ A ≤ B。b ≤ B。假设有A < b,那么我们考虑用B杀a。而不使用A枪也不杀b怪,那么得到的分为B - a,和原来的得分相比,多了b分。少了A分。由于A比b小。所以这种杀怪方式显然得分更大。也就是说,对于某两把枪杀了某两个怪,假设攻击力较低的那把枪杀不了比防御力较高的那个怪。那么就宁愿用攻击力较高的枪去杀防御力较低的怪,不使用攻击力较低的枪也不杀防御力较高的怪。

如此看来,对于一种可行的杀怪方案,要想得分最大,那么必须有随意一把使用了的枪的攻击力的不小于随意一个被杀死的怪的防御力。也就是选出来的全部枪和全部怪。随便用哪把枪杀哪个怪是一样的。既然这样。能够先对枪和怪分别按攻击力递增和防御力递增排序。再用攻击力值最大的枪杀防御力值最小的怪,攻击力值第二大的枪杀防御力值第二大的怪。以此类推。直到杀不了怪为止。求得的得分即为最大值。

#include <iostream>
#include <cstdio>
#include <cmath>
#include <cstring>
#include <string>
#include <algorithm>
#include <stack>
#include <queue>
#include <vector>
#include <map>
#include <set>
using namespace std; const int MAX = 100005; int n, m;
__int64 a[MAX], b[MAX]; void input()
{
scanf("%d%d", &n, &m);
for(int i = 0; i < n; i++)
scanf("%I64d", &a[i]);
for(int i = 0; i < m; i++)
scanf("%I64d", &b[i]);
} void solve()
{
sort(a, a + n);
sort(b, b + m);
__int64 ans = 0;
int i = n - 1, j = 0;
while(i >= 0 && j < m && a[i] > b[j])
ans += a[i--] - b[j++];
printf("%I64d\n", ans);
} int main()
{
int T;
scanf("%d", &T);
while(T--)
{
input();
solve();
}
return 0;
}



HDU 5281 Senior&#39;s Gun 杀怪的更多相关文章

  1. HDU 5281 Senior&#39;s Gun

    Senior's Gun Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) Tot ...

  2. hdu 5281 Senior's Gun

    题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=5281 Senior's Gun Description Xuejiejie is a beautifu ...

  3. HDU 5281 Senior's Gun (贪心)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5281 贪心题目,但是看看我的博客里边相关贪心的题解实在是少的可怜,这里就写出来供大家一起探讨. 题意还 ...

  4. Bestcoder #47 B Senior&#39;s Gun

    Senior's Gun Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) Tot ...

  5. hdu 5282 Senior&#39;s String 两次dp

    题链:http://acm.hdu.edu.cn/showproblem.php?pid=5282 Senior's String Time Limit: 2000/1000 MS (Java/Oth ...

  6. HDU 5280 Senior&#39;s Array

    Senior's Array Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) T ...

  7. HDU 5280 Senior&#39;s Array 最大区间和

    题意:给定n个数.要求必须将当中某个数改为P,求修改后最大的区间和能够为多少. 水题.枚举每一个区间.假设该区间不改动(即改动该区间以外的数),则就为该区间和,若该区间要改动,由于必须改动,所以肯定是 ...

  8. 2159 ACM 杭电 杀怪 二维费用的背包+完全背包问题

    题意:已知经验值,保留的忍耐度,怪的种数和最多的杀怪数.求进入下一级的最优方案. 思路:用二维费用的背包+完全背包问题 (顺序循环)方法求解 什么是二维费用的背包问题? 问题: 二维费用的背包问题是指 ...

  9. HDU 5281 BestCoder Round #47 1002:Senior's Gun

    Senior's Gun  Accepts: 235  Submissions: 977  Time Limit: 2000/1000 MS (Java/Others)  Memory Limit: ...

随机推荐

  1. Ryu基本操作的REST API调用演示样例

    import urllib2 import json def get_all_switches(): url = "http://127.0.0.1:8080/v1.0/topology/s ...

  2. IP地址的规划和设计方法(二)

    五,IP地址规划方法           (1)IP地址规划的基本步骤           网络地址规划须要按下面6步进行:           a)推断用户对网络与主机数的需求:           ...

  3. 网络流Dinic算法模板 POJ1273

    这就是以后我的板子啦~~~ #include <queue> #include <cstdio> #include <cstring> #include <a ...

  4. Android框架-Volley(二)

    1. ImageRequest的用法 前面我们已经学习过了StringRequest和JsonRequest的用法,并且总结出了它们的用法都是非常类似的,基本就是进行以下三步操作即可: 1. 创建一个 ...

  5. angularjs 学习理解

    1AngularJS 是一个 JavaScript 框架.它是一个以 JavaScript 编写的库. 2 ng-app 指令定义一个 AngularJS 应用程序.ng-model 指令把元素值(比 ...

  6. 使用物化视图解决GoldenGate不能使用中文表名问题

    源端: conn sh/sh create table "学生" ("学号" number primary key,"姓名" varchar ...

  7. 20180929 北京大学 人工智能实践:Tensorflow笔记05

    (完)

  8. 紫书 例题 10-16 UVa 12230(数学期望)

    感觉数学期望的和化学里面求元素的相对原子质量的算法是一样的 就是同位素的含量乘上质量然后求和得出 这道题因为等待时机是0到2*l/v均匀分配的,所以平均时间就是l/v 再加上过河的l/v, 最后加上步 ...

  9. POJ——T 1470 Closest Common Ancestors

    http://poj.org/problem?id=1470 Time Limit: 2000MS   Memory Limit: 10000K Total Submissions: 20830   ...

  10. Android笔记---Intent实现Activity跳转

    学了之前的Android控件以及布局,我们就能够做一些UI的设计了,这里我结合之前的知识.以一个小的登录项目来解说下Activity之间跳转. 先看下效果图: 1.登录界面: 2.点击登录按钮跳转到另 ...