DFS:从入门到进阶的刷题指南

目录

一、基础DFS:递归实现、状态标记、回溯

全排列问题

组合问题

子集问题

二、网格DFS:二维矩阵遍历、连通块计数、方向数组

岛屿数量

单词搜索

被围绕的区域

[三、 记忆化DFS:动态规划+DFS,缓存中间结果](#三、 记忆化DFS:动态规划+DFS,缓存中间结果)

斐波那契数列(记忆化版)

滑雪

不同路径(带障碍)

[四、 剪枝优化:可行性剪枝、最优性剪枝、预处理优化](#四、 剪枝优化:可行性剪枝、最优性剪枝、预处理优化)

[N 皇后](#N 皇后)

数独求解

火柴拼正方形

五、树/图的DFS:前序/中序/后序遍历、路径搜索、回溯

二叉树路径和

二叉搜索树的范围和

图中所有路径

六、状态压缩DFS:用二进制表示状态,减少存储开销

[翻转游戏 II](#翻转游戏 II)

解数独

最短哈密尔顿路径

七、综合难题:DFS+贪心、DFS+二分、DFS+并查集

栅栏问题

黄金图形

切断圆环链


一、基础DFS:递归实现、状态标记、回溯

全排列问题

cpp 复制代码
#include <iostream>
using namespace std;
int n;
int a[15];
bool vis[15];
void dfs(int x)
{
    if (x > n)
    {
        for (int i = 1; i <= n; i++)
        {
            printf("%5d", a[i]);
        }
        cout << endl;
        return;
    }
    for (int i = 1; i <= n; i++)
    {
        if (!vis[i])
        {
            vis[i] = true;
            a[x] = i;
            dfs(x + 1);
            vis[i] = false;
            a[x] = 0;
        }
    }
}
int main()
{
    cin >> n;
    dfs(1);
    return 0;
}

组合问题

cpp 复制代码
#include <iostream>
using namespace std;
int n, r;
int a[30];
void dfs(int x, int start)
{
    if (x > r)
    {
        for (int i = 1; i <= r; i++)
        {
            printf("%3d", a[i]);
        }
        cout << endl;
        return;
    }
    for (int i = start; i <= n; i++)
    {

        a[x] = i;
        dfs(x + 1, i + 1);
        a[x] = 0;
    }
}
int main()
{
    cin >> n >> r;
    dfs(1, 1);
    return 0;
}

子集问题

cpp 复制代码
#include <iostream>
using namespace std;
int n;
int a[20];
void dfs(int x)
{
    if (x > n)
    {
        for (int i = 1; i <= n; i++)
        {
            if (a[i] == 1)
            {
                cout << i << " ";
            }
        }
        cout << endl;
        return;
    }
    for (int i = 1; i <= 2; i++)
    {
        a[x] = i;
        dfs(x + 1);
        a[x] = 0;
    }
}
int main()
{
    cin >> n;
    dfs(1);
    return 0;
}

二、网格DFS:二维矩阵遍历、连通块计数、方向数组

岛屿数量

单词搜索

被围绕的区域

**三、 记忆化DFS:**动态规划+DFS,缓存中间结果

斐波那契数列(记忆化版)

滑雪

不同路径(带障碍)

**四、 剪枝优化:**可行性剪枝、最优性剪枝、预处理优化

N 皇后

数独求解

火柴拼正方形

**五、树/图的DFS:**前序/中序/后序遍历、路径搜索、回溯

二叉树路径和

二叉搜索树的范围和

图中所有路径

**六、状态压缩DFS:**用二进制表示状态,减少存储开销

翻转游戏

数独

最短哈密尔顿路径

**七、综合难题:**DFS+贪心、DFS+二分、DFS+并查集

栅栏问题

黄金图形

切断圆环链

相关推荐
君义_noip20 分钟前
信息学奥赛一本通 2134:【25CSPS提高组】道路修复 | 洛谷 P14362 [CSP-S 2025] 道路修复
c++·算法·图论·信息学奥赛·csp-s
kaikaile199532 分钟前
基于拥挤距离的多目标粒子群优化算法(MO-PSO-CD)详解
数据结构·算法
不忘不弃44 分钟前
求两组数的平均值
数据结构·算法
leaves falling1 小时前
迭代实现 斐波那契数列
数据结构·算法
珂朵莉MM1 小时前
全球校园人工智能算法精英大赛-产业命题赛-算法巅峰赛 2025年度画像
java·人工智能·算法·机器人
Morwit1 小时前
*【力扣hot100】 647. 回文子串
c++·算法·leetcode
tobias.b1 小时前
408真题解析-2009-13-计组-浮点数加减运算
算法·计算机考研·408考研·408真题
菜鸟233号2 小时前
力扣96 不同的二叉搜索树 java实现
java·数据结构·算法·leetcode
Coovally AI模型快速验证2 小时前
超越Sora的开源思路:如何用预训练组件高效训练你的视频扩散模型?(附训练代码)
人工智能·算法·yolo·计算机视觉·音视频·无人机
千金裘换酒2 小时前
Leetcode 有效括号 栈
算法·leetcode·职场和发展