1300*C. Slay the Dragon

Example

input

复制代码
4
3 6 2 3
5
3 12
7 9
4 14
1 10
8 7

output

复制代码
1
2
4
0
2

解析:

题意是选一个人去攻击龙,其余人防守龙,可以花费 x 块钱让某英雄能力 +x,问最少的花费是多少。

贪心,选择大于龙的防御力并且最小的那个英雄去攻击(不存在就选择最大的英雄)

二分得出这个英雄,同时和其左侧相邻的英雄比较,花钱少的即为答案。

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N=2e5+5;
ll n,a[N],t,sum,x,y;
int main(){
	scanf("%lld",&n);
	for(int i=1;i<=n;i++) scanf("%lld",&a[i]),sum+=a[i];
	sort(a+1,a+n+1);
	scanf("%lld",&t);
	while(t--){
		ll cnt1=0,cnt2=0;
		scanf("%lld%lld",&x,&y);
		int l=1,r=n;
		while(l<r){		//找出第一个大于等于x的英雄去攻击 
			int mid=l+r>>1;
			if(a[mid]>=x) r=mid;
			else l=mid+1;
		}
		if(a[l]<x) cnt1+=x-a[l];
		if(y-sum+a[l]>0) cnt1+=y-sum+a[l];
		if(l==1){		//如果a[l]是最小值,则cnt1就是答案 
			printf("%lld\n",cnt1);
			continue;
		}
		if(a[l-1]<x) cnt2+=x-a[l-1];	//否则,计算 l 左边相邻的值去攻击 
		if(y-sum+a[l-1]>0) cnt2+=y-sum+a[l-1];
		printf("%lld\n",min(cnt1,cnt2));	//答案即为 l-1和 l两个人花费的较小值 
	}
	return 0;
}
相关推荐
Hello.Reader18 分钟前
算法基础(十)——分治思想把大问题拆成小问题
java·开发语言·算法
CHANG_THE_WORLD1 小时前
C语言中的 %*s 和 %.*s 和C++的字符串格式化输出
c语言·c++·c#
绛橘色的日落(。・∀・)ノ1 小时前
机器学习之评估与偏差方差分析
算法
消失的旧时光-19431 小时前
C语言对象模型系列(四)《Linux 内核里的 container_of 到底是什么黑魔法?》—— 一篇讲透 Linux 内核的“对象模型”核心技巧
linux·c语言·算法
AI_Ming2 小时前
从0开始学AI:层归一化,原来是这回事!
算法·ai编程
WL_Aurora2 小时前
备战蓝桥杯国赛【Day 8】
算法·蓝桥杯
螺丝钉的扭矩一瞬间产生高能蛋白2 小时前
QT的C++接口基础用法
c++·qt·嵌入式软件·嵌入式linux·linux应用
智者知已应修善业2 小时前
【51单片机模拟生日蜡烛】2023-10-10
c++·经验分享·笔记·算法·51单片机
MediaTea2 小时前
Scikit-learn:从数据到结构——无监督学习的最小闭环
人工智能·学习·算法·机器学习·scikit-learn
智者知已应修善业2 小时前
【51单片机如何让LED灯从一亮到八,再从八亮到一】2023-10-13
c++·经验分享·笔记·算法·51单片机