Leetcode上和DFS有关题目整理 (内含目录)

本文通过一系列经典DFS题目,如子集生成、括号生成等,逐步深入讲解了深度优先搜索算法的应用技巧及解题思路。文章覆盖了一维到二维的不同应用场景,并涉及与树结构相结合的问题。

总结一下Leetcode上一些比较经典的利用dfs思路解的题:

按照顺序排了一下,如果从第一道题一直做到最后一道题,会对dfs有一个新的认识。

我们从最典型的开始,首先是关于数字集合的问题,例如输出所有子集,所有序列,我们把这些题当作dfs的基础。

Subset I, II

Combination

Permutation I, II

Combination Combination Sum I, II

接下来,我们明白了dfs一般的解体思路,扩展和一些情景结合的题目:

一维层面上的:

Generate Parentheses

Letter Combination of a Phone number

Restore IP Address

Palindrome Partitioning I (第一种解法)

二维层面上的:

Surrounded Regions

Word search

N Queens I, II

Sudoku solver

还有dfs大量和Tree问题结合,这个我们再单独总结。

博客转载自:http://blog.youkuaiyun.com/u011095253/article/details/9158387

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值