算法设计与分析—(各种解决问题的方法)—回溯法(n皇后问题)

目录

🍓回溯法

🍉核心思想

🍉解题步骤

🍌问题建模

🍌选择起点

🍌递归搜索

🍌约束检查

🍌回溯

🍌终止条件

🍌结果处理

🍉示例

🍌八皇后问题为例:

🍌问题分析

🍌画图演示解题过程

🍊步骤1:初始化棋盘

🍊步骤2:放置第一个皇后

🍊步骤3:放置第二个皇后

🍊步骤4:继续放置

🍊步骤5:回溯

🍊最终解

🍌代码演示解题过程

🍊生成图解

🍓回溯法效率

🍉时间复杂度

🍉空间复杂度

🍓回溯法优缺点

🍉优点

🍉缺点


🍓回溯法

🍉回溯法通常用于求解在一组可能的解决方案中找到满足特定条件的解。它通过尝试每一种可能的选择来解决问题,当发现某个选择不符合条件时,则回溯到前面的步骤,尝试其他的选择。

🍉核心思想

🍌回溯法的核心思想是在解空间中搜索可能的解,并在搜索过程中不断地进行选择和检查,直到找到满足条件的解或者确定无解。当无法继续向前搜索时,算法会回溯到上一步的选择,尝试其他的可能性。这种逐步深入搜索的方法能够高效地解决很多组合优化问题,但需要注意在实现过程中避免重复计算,以提高效率。

🍉解题步骤

🍌问题建模

  • 将问题抽象成一个解空间,明确定义问题的输入、输出和约束条件。

🍌选择起点

  • 确定解空间的起点,并初始化其他必要的变量。

🍌递归搜索

  • 从起点开始,在解空间中递归搜索可能的解决方案。对于每一步,做出一个选择并进行检查,然后继续向下一步递归搜索。

🍌约束检查

  • 在搜索过程中,对每一步做出的选择进行约束检查,确保选择满足问题的约束条件。

🍌回溯

  • 如果当前选择无法满足约束条件,或者达到了问题的终止条件,就回溯到上一步的选择,尝试其他可能的选择。

🍌终止条件

  • 当找到一个满足所有约束条件的解,或者已经尝试了所有可能的选择时,算法终止,返回解决方案或者相应的结果。

🍌结果处理

  • 根据实际需求,对找到的解决方案进行处理,比如输出、存储或其他操作。

🍉示例

🍌八皇后问题为例:

  • 在一个 8x8 的棋盘上放置 8 个皇后,使得彼此之间不能互相攻击(即不能在同一行、同一列或同一对角线上)。

🍌问题分析

1.问题建模将问题抽象成一个解空间,每个解都是一种皇后的布局方式。

2.选择起点在第一行第一列放置一个皇后,并初始化其他变量。

3.递归搜索从第二行开始,在每一列依次尝试放置皇后,并进行递归搜索。

4.约束检查在每次尝试放置皇后时,检查该位置是否与已经放置的皇后冲突。

5.回溯如果当前位置无法放置皇后,则回溯到上一步,尝试下一个位置。

6.终止条件当成功放置了 8 个皇后,或者已经尝试了所有可能的位置时,终止搜索。

7.结果处理如果找到了解决方案,则输出或者进行其他操作;如果没有找到解决方案,则返       回相应的结果。


🍌画图演示解题过程

🍊步骤1:初始化棋盘
  • 首先,我们初始化一个 8 × 8 的棋盘。
. . . . . . . .
. . . . . . . .
. . . . . . . .
. . . . . . . .
. . . . . . . .
. . . . . . . .
. . . . . . . .
. . . . . . . .
🍊步骤2:放置第一个皇后
  • 在第一行的第一个位置放置一个皇后:
Q . . . . . . .
. . . . . . . .
. . . . . . . .
. . . . . . . .
. . . . . . . .
. . . . . . . .
. . . . . . . .
. . . . . . . .
🍊步骤3:放置第二个皇后
  • 在第二行找到一个合法的位置放置皇后:
Q . . . . . . .
. . Q . . . . .
. . . . . . . .
. . . . . . . .
. . . . . . . .
. . . . . . . .
. . . . . . . .
. . . . . . . .
🍊步骤4:继续放置
  • 继续在第三行放置一个皇后,并检查合法位置:
Q . . . . . . .
. . Q . . . . .
. . . . Q . . .
. . . . . . . .
. . . . . . . .
. . . . . . . .
. . . . . . . .
. . . . . . . .
🍊步骤5:回溯
  • 如果某一行没有合法位置放置皇后,回溯到上一行,调整皇后的位置。例如:
Q . . . . . . .
. . Q . . . . .
. . . . Q . . .
. . . . . Q . .
. . . . . . . .
. . . . . . . .
. . . . . . . .
. . . . . . . .
  • 但是发现第四行无合法位置,则回溯:
Q . . . . . . .
. . Q . . . . .
. . . . . Q . .
. . . Q . . . .
. . . . . . . .
. . . . . . . .
. . . . . . . .
. . . . . . . .
🍊最终解
  • 经过不断调整,直到找到一种合法的排列:
Q . . . . . . .
. . . . Q . . .
. . . . . . Q .
. Q . . . . . .
. . . . . Q . .
. . Q . . . . .
. . . . . . . Q
. . . Q . . . .

🍌代码演示解题过程

用Python代码和matplotlib库来画图表示整个解题过程:

import matplotlib.pyplot as plt

def draw_chessboard(queens):
    # 创建一个8x8的棋盘,所有方格初始标记为"."
    board = [["." for _ in range(8)] for _ in range(8)]
    
    # 根据皇后的位置在棋盘上放置皇后
    for r, c in enumerate(queens):
        board[r][c] = "Q"
    
    # 使用matplotlib创建绘图
    fig, ax = plt.subplots()
    
    # 绘制棋盘,使用黑白相间的方格
    ax.matshow([[1 if (i+j) % 2 == 0 else 0 for j in range(8)] for i in range(8)], cmap="gray")
    
    # 在绘图上放置文本表示皇后和空方格
    for r in range(8):
        for c in range(8):
            # 皇后的文本颜色为红色,空方格为黑色
            ax.text(c, r, board[r][c], va='center', ha='center', color="red" if board[r][c] == "Q" else "black")
    
    # 隐藏x和y轴刻度,使绘图更清晰
    plt.xticks([])
    plt.yticks([])
    
    # 显示绘图
    plt.show()

# 示例解(皇后在棋盘上的位置)
queens = [0, 4, 7, 5, 2, 6, 1, 3]

# 根据给定的位置在棋盘上绘制皇后
draw_chessboard(queens)

🍊这段代码会生成一个图示,展示最终的皇后排列情况。你可以根据步骤逐步调整 queens 列表中的位置,来展示每一步的变化。

🍊生成图解


🍓回溯法效率

回溯法的时间复杂度和空间复杂度取决于问题的规模和解空间的大小。通常情况下:

🍉时间复杂度

  • 在最坏情况下,回溯算法需要遍历解空间中的所有可能解,因此时间复杂度通常是指数级别的,记为O(b^d),其中b是每个节点的分支因子(即每个节点的子节点数量),d是问题的深度(即问题的规模)。在某些情况下,通过一些启发式方法或剪枝技术,可以降低时间复杂度。

🍉空间复杂度

  • 回溯算法的空间复杂度取决于递归调用栈的深度,即解空间的搜索深度。在最坏情况下,递归调用栈的深度可能等于问题的规模d,因此空间复杂度通常也是指数级别的,O(d)。然而,在某些情况下,可以通过迭代方式实现回溯,从而减少递归调用栈的深度,降低空间复杂度。

总的来说,回溯算法在处理规模较大的问题时,可能会面临指数级别的时间和空间复杂度,因此对于大规模问题,需要考虑是否存在更有效的算法。


🍓回溯法优缺点

🍉优点

  • 简单易懂: 回溯算法的实现通常比较直观和易于理解,不需要复杂的数据结构或算法知识。

  • 适用性广泛: 回溯算法适用于多种问题,包括组合优化、排列组合、图搜索等问题,因此具有很高的通用性。

  • 能够找到所有解: 回溯算法能够穷尽搜索解空间中的所有可能解,因此可以找到所有满足条件的解。

  • 可以通过剪枝进行优化: 在回溯算法中,可以通过剪枝技术来减少搜索空间,提高算法效率。

🍉缺

  • 时间复杂度高: 在最坏情况下,回溯算法需要遍历解空间中的所有可能解,因此时间复杂度通常是指数级别的,对于大规模问题,性能可能不理想。

  • 空间复杂度高: 回溯算法的空间复杂度取决于递归调用栈的深度,因此在解空间较大的情况下,可能会占用大量的内存空间。

  • 可能会重复搜索: 在搜索解空间时,可能会遇到重复的子问题,导致不必要的重复计算,降低算法效率。

  • 不适用于所有问题: 回溯算法适用于一些特定类型的问题,但不适用于所有问题,例如具有更优解法的问题或者问题规模过大的情况。


希望这些能对刚学习算法的同学们提供些帮助哦!!!

  • 18
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值