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

相关推荐
那个村的李富贵7 小时前
CANN加速下的AIGC“即时翻译”:AI语音克隆与实时变声实战
人工智能·算法·aigc·cann
power 雀儿7 小时前
Scaled Dot-Product Attention 分数计算 C++
算法
Yvonne爱编码7 小时前
JAVA数据结构 DAY6-栈和队列
java·开发语言·数据结构·python
熬夜有啥好7 小时前
数据结构——哈希表
数据结构·散列表
琹箐7 小时前
最大堆和最小堆 实现思路
java·开发语言·算法
renhongxia18 小时前
如何基于知识图谱进行故障原因、事故原因推理,需要用到哪些算法
人工智能·深度学习·算法·机器学习·自然语言处理·transformer·知识图谱
坚持就完事了8 小时前
数据结构之树(Java实现)
java·算法
算法备案代理8 小时前
大模型备案与算法备案,企业该如何选择?
人工智能·算法·大模型·算法备案
赛姐在努力.8 小时前
【拓扑排序】-- 算法原理讲解,及实现拓扑排序,附赠热门例题
java·算法·图论
我能坚持多久8 小时前
【初阶数据结构01】——顺序表专题
数据结构