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 天前
hccl 架构拆解:昇腾集合通信库到底在做什么?
人工智能·经验分享·笔记·分布式·算法·架构
小O的算法实验室1 天前
2026年MCS,Q-learning增强MOPSO与改进DWA融合算法+复杂三维地形下特定移动机器人动态路径规划
算法
Peter·Pan爱编程1 天前
10. new_delete 不是 malloc_free 的包装
c++·人工智能·算法
不知名的老吴1 天前
双栈秒杀表达式的生成方式
数据结构
故事和你911 天前
洛谷-【动态规划1】动态规划的引入2
开发语言·数据结构·c++·算法·动态规划·图论
重生之我是Java开发战士1 天前
【动态规划】背包问题:完全背包,二位费用的背包问题,似包非包
算法·动态规划
LabVIEW开发1 天前
LabVIEW实现FDTD 电磁仿真
算法·labview·labview知识·labview功能·labview程序
Together_CZ1 天前
DTSemNet :Vanilla Gradient Descent for Oblique Decision Trees——用于倾斜决策树的普通梯度下降
算法·决策树·机器学习·vanilla·gradient·dtsemnet·用于倾斜决策树的普通梯度
一条大祥脚1 天前
ABC459 贪心构造|树形DP|组合数学|贪心|单调栈|势能|前缀和
算法·深度优先
灰灰勇闯IT1 天前
DeepEP:MoE 推理的 AllToAll 通信瓶颈怎么解
算法·cann