LeetCode 212. Word Search II

简介: 给定一个二维网格 board 和一个字典中的单词列表 words,找出所有同时在二维网格和字典中出现的单词。单词必须按照字母顺序,通过相邻的单元格内的字母构成,其中“相邻”单元格是那些水平相邻或垂直相邻的单元格。同一个单元格内的字母在一个单词中不允许被重复使用。

v2-7b066acf6e7720c7e5a505600ed24a73_1440w.jpg

Description



Given a 2D board and a list of words from the dictionary, find all words in the board.


Each word must be constructed from letters of sequentially adjacent cell, where "adjacent" cells are those horizontally or vertically neighboring. The same letter cell may not be used more than once in a word.


Example:


Input:

words = ["oath","pea","eat","rain"] and board =

[

['o','a','a','n'],

['e','t','a','e'],

['i','h','k','r'],

['i','f','l','v']

]


Output: ["eat","oath"]

Note:

You may assume that all inputs are consist of lowercase letters a-z.


描述



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


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


示例:


输入:

words = ["oath","pea","eat","rain"] and board =

[

['o','a','a','n'],

['e','t','a','e'],

['i','h','k','r'],

['i','f','l','v']

]

输出: ["eat","oath"]


思路



  • 这道题使用Trie这种数据结构,使用深度右边遍历这种数据结构.
  • 为了提前结束回溯,我们将要搜索的字符串构造成一颗Trie树,这样当有某个字符没有出现在给定的board中时,我们就可以结束回溯.


# -*- coding: utf-8 -*-
# @Author:             何睿
# @Create Date:        2019-01-22 20:38:32
# @Last Modified by:   何睿
# @Last Modified time: 2019-01-23 23:03:28
class TrieNode:
    def __init__(self):
        self.children = {}
        self.word = ''
class Solution:
    def __init__(self):
        self.root = None
        self.res = []
    def findWords(self, board, words):
        """
        :type board: List[List[str]]
        :type words: List[str]
        :rtype: List[str]
        """
        # 如果为空则直接返回
        if not board or not words: return []
        # 生成一颗Trie树
        self.createTrie(words)
        # 获取矩阵宽度和高度
        row, col = len(board), len(board[0])
        ischecked = [[False for _ in range(col)] for _ in range(row)]
        # 以每一个位置为出发点进行检查
        for i in range(row):
            for j in range(col):
                self.dfs(i, j, self.root, row, col, board, ischecked)
        return self.res
    def dfs(self, i, j, node, row, col, board, ischecked):
        # 如果是一个完整的单词,添加该单词,并将该单词置为空,避免重复
        if node.word:
            self.res.append(node.word)
            node.word = ''
        # 如果当前位置已经越界,则直接返回
        if i < 0 or i >= row or j < 0 or j >= col or ischecked[i][j]: return
        # 如果当前的字符不在trie中,返回
        if board[i][j] not in node.children: return
        # 能够执行到这里,说明该字符存在与Tire中,将当前的位置标记为已经访问过
        # 更新节点
        ischecked[i][j], newnode = True, node.children[board[i][j]]
        # 向上走一步
        self.dfs(i - 1, j, newnode, row, col, board, ischecked)
        # 想右走一步
        self.dfs(i + 1, j, newnode, row, col, board, ischecked)
        # 向左走一步
        self.dfs(i, j - 1, newnode, row, col, board, ischecked)
        # 向右走一步
        self.dfs(i, j + 1, newnode, row, col, board, ischecked)
        # 重置当前位置为未访问过
        ischecked[i][j] = False
    def createTrie(self, words):
        self.root = TrieNode()
        for word in words:
            node = self.root
            for char in word:
                if char not in node.children:
                    node.children[char] = TrieNode()
                node = node.children[char]
            node.word = word
        return

源代码文件在这里.


目录
相关文章
|
5月前
Leetcode 74. Search a 2D Matrix
这道题很简单,为此专门写篇博客其实算博客凑数了。给你一个每一行每一列都是增序,且每一行第一个数都大于上一行末尾数的矩阵,让你判断某个数在这个矩阵中是否存在。 假设矩阵是m*n,扫一遍的时间复杂度就是O(m*n),题目中给出的这么特殊的矩阵,时间复杂度可以降到O(m+n),具体代码如下,写的比较挫。
62 1
|
算法 Python
LeetCode 108. 将有序数组转换为二叉搜索树 Convert Sorted Array to Binary Search Tree
LeetCode 108. 将有序数组转换为二叉搜索树 Convert Sorted Array to Binary Search Tree
LeetCode 318. Maximum Product of Word Lengths
给定一个字符串数组 words,找到 length(word[i]) * length(word[j]) 的最大值,并且这两个单词不含有公共字母。你可以认为每个单词只包含小写字母。如果不存在这样的两个单词,返回 0。
52 0
LeetCode 318. Maximum Product of Word Lengths
LeetCode 290. Word Pattern
给定一种 pattern(模式) 和一个字符串 str ,判断 str 是否遵循相同的模式。 这里的遵循指完全匹配,例如, pattern 里的每个字母和字符串 str 中的每个非空单词之间存在着双向连接的对应模式。
31 0
LeetCode 290. Word Pattern
|
索引
LeetCode 81. Search in Rotated Sorted Array II
假设按升序排序的数组在事先未知的某个枢轴处旋转。 (例如, [0,0,1,2,2,5,6] 可能变成 [2,5,6,0,0,1,2]). 给定一个要搜索的目标值T, 如果该目标值能在数组中找到则返回true,否则返回false。
62 0
LeetCode 81. Search in Rotated Sorted Array II
|
索引
LeetCode 79. Word Search
给定一个2D板和一个单词,找出该单词是否存在于网格中。 该单词可以由顺序相邻的单元的字母构成,其中“相邻”单元是水平或垂直相邻的单元。 相同的字母单元格不得多次使用。
49 0
LeetCode 79. Word Search
|
算法
LeetCode 74. Search a 2D Matrix
编写一个有效的算法,搜索m×n矩阵中的值。 此矩阵具有以下属性: 每行中的整数从左到右排序. 每行的第一个整数大于前一行的最后一个整数.
50 0
LeetCode 74. Search a 2D Matrix
|
机器学习/深度学习
Leetcode-Medium 96.Unique Binary Search Trees
Leetcode-Medium 96.Unique Binary Search Trees
76 0
|
算法 Python
Leetcode-Medium 98. Validate Binary Search Tree
Leetcode-Medium 98. Validate Binary Search Tree
108 0
LeetCode之Search Insert Position
LeetCode之Search Insert Position
79 0