饿了么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 广东

相关推荐

点赞 评论 收藏
分享
04-11 23:51
门头沟学院 Java
坚定的芭乐反对画饼_许愿Offer版:人人都能过要面试干嘛,发个美团问卷填一下,明天来上班不就好了
点赞 评论 收藏
分享
评论
3
3
分享

创作者周榜

更多
牛客网
牛客企业服务