L---泰拉瑞亚---2023河南萌新联赛第(三)场:郑州大学

链接:登录---专业IT笔试面试备考平台_牛客网

来源:牛客网

示例1

输入

复制代码
1 10
3 5

输出

复制代码
3

说明

只有一把回旋镖,你可以先打两次伤害为3的,再打一次倾尽全力的,造成的伤害为5。总伤害为3+3+5=11,即可获得胜利。

示例2

输入

复制代码
2 100
1 30
1 20

输出

复制代码
52

说明

你可以先把第一把倾尽全力打出去,造成30伤害。接下来用第二把连续攻击50次,造成50伤害。最后把第二把也打出去,造成20伤害。总伤害为30+50+20,即可击杀。

解析:

贪心,计算出 "重复扔" 伤害的最大值 mx,然后把比mx伤害高的全部 "全力" 扔出,最后剩余的血量用mx重复扔即可。

这里有个疑问,如果"重复扔"的最大伤害和 "全力扔" 的最大伤害是同一把飞镖 p ,那么这样计算不会把这个 p 也扔出去吗?

不影响结果,因为这个飞镖 p 的"全力扔"伤害比"重复扔"高,那么最后一次必定会全力扔 p ,所以可以先计算进去,不影响结果。

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N=1e5+5;
int n,h,mx,a[N],cnt,t;
int main(){
	scanf("%d%d",&n,&h);
	for(int i=1;i<=n;i++){
		scanf("%d%d",&t,&a[i]);
		mx=max(mx,t);
	}
	sort(a+1,a+1+n);
	reverse(a+1,a+1+n);
	for(int i=1;h>0&&i<=n;i++){
		if(a[i]>mx) h-=a[i],cnt++;
		else break;
	}
	if(h>0&&h%mx) cnt++;
	printf("%d",h>0?cnt+h/mx:cnt);
	return 0;
}
相关推荐
承渊政道几秒前
C++学习之旅【C++基础知识介绍】
c语言·c++·学习·程序人生
民乐团扒谱机2 分钟前
【微实验】大规模网络的社区检测Clauset–Newman–Moore聚类算法(附完整MATLAB代码)
算法·matlab·聚类·聚类算法·cnm·语义
烛衔溟2 分钟前
C语言图论:有向图基础
c语言·数据结构·图论·有向图
枫叶丹44 分钟前
【Qt开发】Qt窗口(七) -> QColorDialog 颜色对话框
c语言·开发语言·c++·qt
闻缺陷则喜何志丹6 分钟前
【计算几何】三角函数的和角公式、矢量旋转
c++·数学·计算几何·三角函数和角公式·矢量旋转
4***99747 分钟前
工业网关助力Altivar320与S7-1200协同运行
ide·python·算法·spring·eclipse·sqlite·tornado
IT·小灰灰8 分钟前
DeepSeek-V3.2:开源大模型的里程碑式突破与硅基流动平台实战指南
大数据·人工智能·python·深度学习·算法·数据挖掘·开源
渡我白衣9 分钟前
计算机组成原理(2):计算机硬件的基本组成
运维·服务器·网络·c++·人工智能·网络协议·dubbo
AI视觉网奇9 小时前
Fatal signal 11 (SIGSEGV), code 1 (SEGV_MAPERR), fault addr
开发语言·c++·算法
ghie90909 小时前
ECG波形检查与分析系统
算法