牛客小白月赛104 —— C.小红打怪

C.小红打怪

1.题目:

2.样例

输入

cpp 复制代码
5
1 2 3 4 5

输出

cpp 复制代码
2

说明

第一回合,小红攻击全体怪物,队友1攻击5号怪物,队友2攻击4号和5号怪物,剩余每只怪物血量为[0,1,2,2,2]。

第二回合,小红攻击全体怪物,队友1攻击5号怪物,队友2攻击3号和4号怪物,即可击杀所有怪物。

3.思路

其实这题就是心里想的那样的,我当时以为有什么简单的方法,没想到就是暴力过的

我们用二分答案法,从1------数组中的最大值,如果mid满足条件,则用res保存答案,向左边二分,找到最小的回合数;不满足条件,不保存答案,向右边二分。

那么这个条件是什么呢?

我们在确定了回合数的情况下,怎么判断是否满足条件,我们先使用小红的技能,用数组b记录怪兽剩余的血量,再使用队友二的范围攻击,为了不浪费技能,我们一定要确保相邻的两个怪兽有血量,且是刚好使该怪兽血量变为零,如果没有相邻两个怪兽有血量,那么把剩余的队友二的技能次数跟队友一的技能次数合并相加,就当作单个技能技能攻击使用,然后不断的枚举怪兽的剩余血量,如果还有血量,就清零,把技能使用次数也减少,如果技能使用次数变为负数或者i没有到n+1,这说明这个回合数不满足条件。

具体代码实现:

cpp 复制代码
#include <iostream>
using namespace std;
const int N = 1e5+10;
int n,m,res;
int a[N],b[N];

bool check(int x){
	b[0]=0;
	int x1=x;
	for(int i=1;i<=n;i++){
		b[i]=a[i]-x;
		if(b[i]>0&&b[i-1]>0){
			int t=min(b[i],b[i-1]);
			t=min(x1,t);
			x1-=t;	//不用弄额外的条件去限制x1
			//因为x1最后一定是>=0,因为t=min(t,x1) 
			b[i]-=t;
			b[i-1]-=t;
		}
	}
	
	int x2=x+x1;
	int i=1;
	for(;i<=n;i++){
		if(b[i]>0){
			x2-=b[i];
			b[i]=0;	
		}
		if(x2<0)
		break;
	}
	if(i==n+1&&x2>=0){
		return true;
	}
	else{
		return false;
	}
} 

void solve(){
	int l=1,r=m;
	while(l<=r){
		int mid=l+(r-l)/2;
		if(check(mid)){
			res=mid;
			r=mid-1;
		}
		else{
			l=mid+1;
		}
	}
	printf("%d\n",res);
}

int main(void){
	cin>>n;
	for(int i=1;i<=n;i++){
		cin>>a[i];
		m=max(m,a[i]);
	}
	solve();
	return 0;
}
相关推荐
宁静致远20216 分钟前
Ubuntu下的Doxygen+VScode实现C/C++接口文档自动生成
c++·vscode·ubuntu
Bluesonli11 分钟前
第 2 天:创建你的第一个 UE5 C++ 项目!
c++·学习·ue5·虚幻·虚幻引擎·unreal engine
追求源于热爱!28 分钟前
记4(可训练对象+自动求导机制+波士顿房价回归预测
图像处理·人工智能·算法·机器学习·回归
比特在路上32 分钟前
蓝桥杯之c++入门(四)【循环】
c++·职场和发展·蓝桥杯
pay顿1 小时前
C++基础day1
c++·学习·笔试
孤寂码农_defector1 小时前
C++【iostream】数据库的部分函数功能介绍
c++
qq_433618441 小时前
哈夫曼树
数据结构·算法
Icomi_1 小时前
【PyTorch】7.自动微分模块:开启神经网络 “进化之门” 的魔法钥匙
c语言·c++·人工智能·pytorch·python·机器学习·计算机视觉
余辉zmh1 小时前
【贪心算法篇】:“贪心”之旅--算法练习题中的智慧与策略(二)
c++·算法·leetcode·贪心算法
余辉zmh1 小时前
【贪心算法篇】:“贪心”之旅--算法练习题中的智慧与策略(一)
c++·算法·leetcode·贪心算法