算法随笔_57 : 游戏中弱角色的数量

上一篇:算法随笔_56: 好子数组的最大分数-CSDN博客

=====

题目描述如下:

你正在参加一个多角色游戏,每个角色都有两个主要属性:攻击防御 。给你一个二维整数数组 properties ,其中 properties[i] = [attacki, defensei] 表示游戏中第 i 个角色的属性。

如果存在一个其他角色的攻击和防御等级 都严格高于 该角色的攻击和防御等级,则认为该角色为 弱角色 。更正式地,如果认为角色 i 弱于 存在的另一个角色 j ,那么 attackj > attackidefensej > defensei

返回 弱角色 的数量。

示例 1:

复制代码
输入:properties = [[5,5],[6,3],[3,6]]
输出:0
解释:不存在攻击和防御都严格高于其他角色的角色。

=====

算法思路:

这道题需要比较两个属性"攻击力"和"防御力"。我们可以先对"攻击力"属性对原数组进行升序排列。那么只要前面元素的"防御力"值小于后面元素的"防御力"值,我们就找到了一个弱角色。

我们可以使用"栈"的数据结构来维护"防御力"值。我们设数组stck为此栈,初始值为 stck=properties\[01]。

当"防御力"值propertiesi1小于stck-1栈顶时,propertiesi1入栈。当propertiesi1不断大于stck-1,stck-1不断弹出。那么弹出的那些元素即为弱角色。

这道题还有一点需要注意,因为它要求严格大于。因此我们可以在排列原数组的时候,加一个限定条件,即,当元素之间的"攻击力"相同时,按"防御力"递减排列。

这样的话,如果出现元素 i 的"防御力"值大于栈顶的元素,那么这个元素 i 一定与栈顶的元素攻击力不同,且比它大。这样上面的算法就不会影响最终的结果。

下面是代码实现:

复制代码
class Solution(object):
    def numberOfWeakCharacters(self, properties):
        """
        :type properties: List[List[int]]
        :rtype: int
        """
        p_len=len(properties)
        properties.sort(key=lambda x: (x[0], -x[1]))
        stck=[properties[0][1]]
        res=0
        for i in range(1, p_len):
            while stck and properties[i][1]>stck[-1]:
                res+=1
                stck.pop()   
            stck.append(properties[i][1])
        return res

关键词: 单调栈

相关推荐
风吹夏回17 小时前
Python 全局异常处理:从“满屏 try-except”到优雅兜底
开发语言·python
kkeeper~18 小时前
0基础C语言积跬步之数据在内存中的存储
c语言·数据结构·算法
小熊Coding18 小时前
Python爬取当当网二手图书项目实战!
开发语言·爬虫·python·beautifulsoup·requests·二手图书
秋918 小时前
Java项目运行5天左右自动宕机:系统性定位与解决方案
java·开发语言·python
小江的记录本18 小时前
【JVM虚拟机】垃圾回收GC:垃圾收集器:CMS:核心原理、回收流程、优缺点、废弃原因(附《思维导图》+《面试高频考点清单》)
java·jvm·后端·python·spring·面试·maven
2401_8685347818 小时前
论企业网络设计
数据结构
田里的水稻19 小时前
OE_ubuntu26.04与宿主机之间复制粘贴内容
人工智能·python·机器人
wabs66619 小时前
关于贪心算法的一些自我总结【力扣45.跳跃游戏II】【灵感来源:代码随想录】
算法·贪心算法·复盘
2401_8769641319 小时前
【湖北专升本】2026湖北专升本真题PDF+备考资料汇总
数据结构·人工智能·经验分享·深度学习·算法·计算机视觉
jiayong2320 小时前
02 创建虚拟环境
python