python leetcode 130. Surrounded Regions

221 篇文章 2 订阅

注意遍历的顺序,从四周开始。与Pacific Atlantic Water Flow类似。

class Solution(object):
    def solve(self, board):
        """
        :type board: List[List[str]]
        :rtype: void Do not return anything, modify board in-place instead.
        """
        visit=set()
        change=set()
        m=len(board)
        if m==0: return 
        n=len(board[0])
        def dfs(board,x,y,visit):
            visit.add((x,y))
            res={(x,y)}
            for dx,dy in zip((-1,0,1,0),(0,-1,0,1)):
                nx,ny=x+dx,y+dy
                if nx<0 or nx>=len(board) or ny<0 or ny>=len(board[0]) or board[nx][ny]=='X' or (nx,ny) in visit:
                    continue
                res=res| dfs(board,nx,ny,visit)
            return res 
        for i in range(m):
            if board[i][0] == 'O' and (i,0) not in visit:
                change=change|dfs(board,i,0,visit)
        for i in range(m):
            if board[i][n-1] == 'O' and (i,n-1) not in visit:
                change=change|dfs(board,i,n-1,visit)
        for j in range(1,n-1):
            if board[0][j]=='O' and (0,j) not in visit:
                change=change|dfs(board,0,j,visit)
        for j in range(1,n-1):
            if board[m-1][j]=='O' and (m-1,j) not in visit:
                change=change|dfs(board,m-1,j,visit)
        for i in range(m):
            for j in range(n):
                if board[i][j]=='X' or (i,j) in change:
                    continue 
                board[i][j]='X'
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值