【Leetcode每日一题】212. 单词搜索 II



题目

给定一个 m x n 二维字符网格 board 和一个单词(字符串)列表 words,找出所有同时在二维网格和字典中出现的单词。

单词必须按照字母顺序,通过 相邻的单元格 内的字母构成,其中“相邻”单元格是那些水平相邻或垂直相邻的单元格。同一个单元格内的字母在一个单词中不允许被重复使用。

示例

示例1

输入:board = [[“o”,“a”,“a”,“n”],[“e”,“t”,“a”,“e”],[“i”,“h”,“k”,“r”],[“i”,“f”,“l”,“v”]], words = [“oath”,“pea”,“eat”,“rain”]
输出: [“eat”,“oath”]

示例2

输入:board = [[“a”,“b”],[“c”,“d”]], words = [“abcb”]
输出:[]


代码实现

class Solution(object):
    def findWords(self, board, words):
        """
        :type board: List[List[str]]
        :type words: List[str]
        :rtype: List[str]
        """

        result = []

        for word in words:  # "oath" in [...]
            for i in range(len(board)):  # "["o","a","a","n"]" in [...]
                for j, c in enumerate(board[i]):  # j:index, c:character
                    if c == word[0]:
                        row,column = i,j
                        for k in range(1,len(word)):  # 'o' in "oath"
                            if row!=0 and board[row-1][column]==word[k]:  # up
                                row = row-1
                            elif row != len(board)-1 and board[row+1][column]==word[k]:  # down
                                row = row+1
                            elif column != 0 and board[row][column-1]==word[k]:  # left
                                column = column-1
                            elif column != len(board)-1 and board[row][column+1]==word[k]:  # right
                                column = column+1
                            else:
                                break
                            if k == len(word)-1:
                                result.append(word)

        return result


if __name__ == "__main__":
    board = input()
    words = input()
    obj = Solution()
    result = obj.findWords(board, words)
    print(result)

运行结果

[“eat”,“oath”]
[]

链接

https://leetcode-cn.com/problems/word-search-ii

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值