python 炸敌人。

给定一个二维矩阵,每一个格子可能是一堵墙 W、一个敌人E或者空0(数字0)。返回用一个炸弹可杀死的最多敌人数。炸弹会杀死所有在同一行和同一列没有墙阻隔的敌人墙不会被摧毁,只能在空地放置炸弹。

python 复制代码
class Solution:
    def maxKilledEnemies(self, grid):
        rows = len(grid)
        cows = len(grid[0])
        cnt = 0
        for i in range(rows):
            for j in range(cows):
                if grid[i][j] == '0':
                    #  分析所在行合理范围有几个E,j在变化
                    s = 0
                    n = j - 1
                    while n >= 0:
                        if grid[i][n] == 'E':
                            s += 1
                        elif grid[i][n] == 'W':
                            break
                        n -= 1
                    n = j + 1
                    while n < cows:
                        if grid[i][n] == 'E':
                            s += 1
                        elif grid[i][n] == 'W':
                            break
                        n += 1
                        #  分析所在列合理范围有几个E, i在变化
                    n = i - 1
                    while n >= 0:
                        if grid[n][j] == 'E':
                            s += 1
                        elif grid[n][j] == 'W':
                            break
                        n -= 1
                    n = i + 1
                    while n < rows:
                        if grid[n][j] == 'E':
                            s += 1
                        elif grid[n][j] == 'W':
                            break
                        n += 1
                    cnt = max(cnt, s)
        return cnt


if __name__ == '__main__':
    g = [
        "0E00",
        "E0WE",
        "0E00"
    ]
    solution = Solution()
    print(solution.maxKilledEnemies(g))
相关推荐
Doopny@13 分钟前
新矩阵(信息学奥赛一本通-2041)
算法
qq_4335545424 分钟前
C++ 邻接矩阵(代码)
c++·算法
Student_Zhang1 小时前
推荐一个数据加密的框架GMObjc(iOS)
前端·算法·github
Useee3 小时前
DAY33 贪心算法Ⅱ
算法·贪心算法
酷酷的崽7983 小时前
【栈数据结构应用解析:常见算法题详细解答】—— Leetcode
数据结构·算法·leetcode
Book_熬夜!3 小时前
数据结构——环形数组
javascript·数据结构·算法
奋斗者1号3 小时前
Python 中 lambda 表达式、推导式和其他函数用法对比
开发语言·python·算法
誓约酱6 小时前
(每日一题) 力扣 179 最大数
c语言·c++·算法·leetcode·职场和发展
2301_792185886 小时前
力扣:3305.元音辅音字符串计数
c++·算法·leetcode
奔跑的废柴6 小时前
LeetCode 112. 路径总和 II java题解
java·算法·leetcode·二叉树