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

相关推荐
踩坑记录1 小时前
leetcode hot100 寻找两个正序数组的中位数 hard 二分查找 双指针
leetcode
旖-旎1 小时前
深搜练习(电话号码字母组合)(3)
c++·算法·力扣·深度优先遍历
谭欣辰1 小时前
C++快速幂完整实战讲解
算法·决策树·机器学习
Mr_pyx1 小时前
【LeetHOT100】随机链表的复制——Java多解法详解
算法·深度优先
AIFarmer1 小时前
【无标题】
开发语言·c++·算法
AGV算法笔记2 小时前
CVPR 2025 最新感知算法解读:GaussianLSS 如何用 Gaussian Splatting 重构 BEV 表示?
算法·重构·自动驾驶·3d视觉·感知算法·多视角视觉
勤劳的进取家2 小时前
数据链路层基础
网络·学习·算法
Advancer-3 小时前
第二次蓝桥杯总结(上)
java·算法·职场和发展·蓝桥杯
ん贤3 小时前
加密算法(对称、非对称、哈希、签名...)
算法·哈希算法
superior tigre4 小时前
78 子集
算法·leetcode·深度优先·回溯