单词搜索
https://www.lintcode.com/problem/123/?utm_source=sc-libao-ql
描述
给出一个二维的字母板和一个字符串单词,寻找字母板网格中是否存在这个字符串单词。
字符串单词可以由按顺序的相邻单元的字母组成,其中相邻单元指的是水平或者垂直方向相邻。
每个单元中的字母最多只能使用一次。
字母矩阵的维度均不超过100,字符串长度不超过100。
样例
样例 1:
输入:
输出:
解释:
[
A B C E
S F C S
A D E E
]
(0,0)->(0,1)->(0,2)->(1,2)->(2,2)->(2,1)
样例 2:
输入:
输出:
解释:
[ z ]
(0,0)
分析:
用回溯backtracking, 区别dfs和backtrack和dp with memo:
回溯有剪枝,放弃无效路径立刻回溯,是特殊的dfs。普通dfs会遍历所有的可能性。而回溯通常只有一个Unique path
dp带memo是有大量重复子问题,需要保存,占内存。
本体有剪枝,重复子问题少,减枝,无需保存子状态。
注意需要记录已经visited过的点,这里直接每次递归前替换来处的点,而不是创建整个m*n数组来记载visited.
Last updated
Was this helpful?