题目

解题
这个题目 还是回溯法
from typing import *
def solution(board: List[List[str]], word: str):
    if not board:
        return False
    visited = [[False for _ in range(len(board[0]))] for _ in range(len(board))]
    def dfs(board, i, j, word, k, visited):
        if k == len(word):
            return True
        if i < 0 or i >= len(board) or j < 0 or j >= len(board[0]) or board[i][j] != word[k] or visited[i][j]:
            return False
        visited[i][j] = True
        res = dfs(board, i + 1, j, word, k + 1, visited) or \
              dfs(board, i - 1, j, word, k + 1, visited) or \
              dfs(board, i, j + 1, word, k + 1, visited) or \
              dfs(board, i, j - 1, word, k + 1, visited)
        visited[i][j] = False
        return res
    for i in range(len(board)):
        for j in range(len(board[0])):
            if dfs(board, i, j, word, 0, visited):
                return True
    return False