饿了么3.23 人麻了

第一题做不来,给我学建筑的npy10分钟解出来了
😭😭😭

题目:
你正在玩一款打怪游戏,你会两个技能,技能1:旋风斩,让所以怪扣一滴血,消耗一点体力;技能2:斩杀,直接杀死一个不是满血的怪,消耗2点体力。求杀死所有小怪花费的最少体力。

解题:
nums记录所有小怪都血量。
先对nums从小到大排序。
p,q是数组下标,一开始为0和nums.size-1,指向小怪血量的最小/最大值。
skill1记录旋风斩消耗的体力。
skill2记录斩杀消耗的体力。
上来先旋风斩一刀skill1=1,p向右移动直到nums[p]>skill1。
如果(nums[q]-skill1)/2skill1。
否则,用一次斩杀,杀掉nums[q],skill += 2,q -= 1。
一直循环直到p>q。
最后返回skill1+skill2
还是贪心的思路。
全部评论
感谢
点赞 回复 分享
发布于 2024-03-25 13:07 浙江
测试输入 1 1 4 答案 3 解释: 1刀旋风斩变成 0 0 3,再来一刀斩杀即可
点赞 回复 分享
发布于 2024-03-24 23:32 广东

相关推荐

野猪不是猪🐗:😇:恭喜你以出色的表现成为xxx的一员 😨:您以进入本公司人才库 实际点开:您愿望单中的xxx正在特卖!
点赞 评论 收藏
分享
09-22 15:45
门头沟学院 Java
谁给娃offer我给...:我也遇到了,我说只要我通过面试我就去,实际上我根本就不会去😁
点赞 评论 收藏
分享
评论
3
3
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务