欢乐力扣:矩阵置零


1、题目描述

矩阵置0,给定一个 m x n 的矩阵,如果一个元素为 0 ,则将其所在行和列的所有元素都设为 0 。请使用原地算法。
在这里插入图片描述

2、 代码

class Solution:
    def spiralOrder(self, matrix: List[List[int]]) -> List[int]:
        if not matrix or not matrix[0]:
            return []

        ans = []
        left = 0 
        right = len(matrix[0]) - 1  
        top = 0 
        bottom = len(matrix) - 1 
        # 假设只有一个元素,则需要left==right情况,因此是 <= 
        while left <= right and top <= bottom:
            # 从左到右
            for i in range(left, right + 1):
                ans.append(matrix[top][i])
            top +=1 
            # 从上到下
            for i in range(top, bottom+1):
                ans.append(matrix[i][right])
            
            right -= 1

            # 从右到左, 由于top+=1扩大了了边界,可能超过bottom,发生重复遍历
            # 因此需要加if判断
            if top <= bottom:
                for i in range(right, left-1, -1):
                    ans.append(matrix[bottom][i])
            
            bottom -= 1

            # 从下到上,同理,需要加if判断
            if left <= right:
                for i in range(bottom, top-1, -1):
                    ans.append(matrix[i][left])
            
            left += 1 
        return ans 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值