0x3f 第40天 setnx的分布式锁和redission,写了一天项目书,光背了会儿八股,回溯(单词搜索)

单词搜索

可以评到难的程度,和N皇后难度差不多,虽然逻辑简单一点

剪枝1:把board里的cnt一遍,如果要查的word的cnt比board的多,那肯定无解

剪枝2:考虑word的第一个字母出现的多,还是word的最后一个字母出现的多

核心思路:先剪枝

循环体需要三个参数,i,j负责定位,k负责指向目前在查word的第k个字母

i,j 不等于第k个字母False

已经遍历到第k个字母,在结合前面没有返回False,那就说明True

循环体:遍历过的都做标记,和寻找岛屿一样

用xy来找上下左右有没有符合的

if 0<=x<m and 0<=y<n and dfs(x,y,k+1):

如果没找到

恢复现场

return False

最终遍历使用any 因为任何一个点都可以是查询的起点

复制代码
class Solution:
    def exist(self, board: List[List[str]], word: str) -> bool:
        cnt = Counter(c for row in board for c in row)
        #剪枝
        if cnt<Counter(word):
            return False
        #剪枝
        if cnt[word[-1]]<cnt[word[0]]:
            word = word[::-1]
        m,n = len(board),len(board[0])
        def dfs(i,j,k):
            if board[i][j] != word[k]:
                return False
            if k == len(word)-1:
                return True
            board[i][j] = ''
            for x,y in (i,j-1),(i,j+1),(i+1,j),(i-1,j):
                if 0<=x<m and 0<=y<n and dfs(x,y,k+1):
                    return True
            board[i][j] = word[k]
            return False
        return any(dfs(i,j,0)for i in range(m) for j in range(n))

黑马点评:setnx和redission

相关推荐
颜酱8 小时前
单调栈:从模板到实战
javascript·后端·算法
CoovallyAIHub11 小时前
仿生学突破:SILD模型如何让无人机在电力线迷宫中发现“隐形威胁”
深度学习·算法·计算机视觉
CoovallyAIHub11 小时前
从春晚机器人到零样本革命:YOLO26-Pose姿态估计实战指南
深度学习·算法·计算机视觉
CoovallyAIHub11 小时前
Le-DETR:省80%预训练数据,这个实时检测Transformer刷新SOTA|Georgia Tech & 北交大
深度学习·算法·计算机视觉
CoovallyAIHub12 小时前
强化学习凭什么比监督学习更聪明?RL的“聪明”并非来自算法,而是因为它学会了“挑食”
深度学习·算法·计算机视觉
CoovallyAIHub12 小时前
YOLO-IOD深度解析:打破实时增量目标检测的三重知识冲突
深度学习·算法·计算机视觉
NAGNIP1 天前
轻松搞懂全连接神经网络结构!
人工智能·算法·面试
NAGNIP1 天前
一文搞懂激活函数!
算法·面试
董董灿是个攻城狮1 天前
AI 视觉连载7:传统 CV 之高斯滤波实战
算法