当前位置: 首页 > article >正文

【第八天】零基础入门刷题Python-算法篇-数据结构与算法的介绍-一种常见的回溯算法(持续更新)

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录

  • 前言
  • 一、Python数据结构与算法的详细介绍
    • 1.Python中的常用的回溯算法
      • 2. 回溯算法
      • 3.详细的回溯算法
        • 1)一种常见的回溯算法
  • 总结


前言

提示:这里可以添加本文要记录的大概内容:

第一天Python数据结构与算法的详细介绍
第二天五种常见的排序算法
第三天两种常见的搜索算法
第四天两种常见的递归算法
第五天一种常见的动态规划算法
第六天一种常见的贪心算法
第七天一种常见的分治算法
第八天一种常见的回溯算法

提示:以下是本篇文章正文内容,下面案例可供参考

一、Python数据结构与算法的详细介绍

1.Python中的常用的回溯算法

以下是Python中的一些常用算法:

2. 回溯算法

回溯算法:通过搜索所有可能的候选解来找出所有解的算法。如果候选解被确认不是一个解(或者至少不是最后一个解),回溯算法会通过在上一步进行一些变化来丢弃该解,即“回溯”并尝试另一个可能的候选解。时间复杂度通常很高,因为需要探索所有可能的解空间。

3.详细的回溯算法

1)一种常见的回溯算法
def solve_n_queens(n):
    def is_safe(board, row, col):
        # 检查列上是否有皇后
        for i in range(row):
            if board[i][col] == 1:
                return False
        
        # 检查左上对角线是否有皇后
        i, j = row, col
        while i >= 0 and j >= 0:
            if board[i][j] == 1:
                return False
            i -= 1
            j -= 1
        
        # 检查右上对角线是否有皇后
        i, j = row, col
        while i >= 0 and j < n:
            if board[i][j] == 1:
                return False
            i -= 1
            j += 1
        
        return True

    def solve(board, row):
        # 如果所有行都已成功放置皇后,则找到一个解
        if row >= n:
            result.append(["".join(["Q" if board[i][j] == 1 else "." for j in range(n)]) for i in range(n)])
            return
        
        # 尝试在当前行的每一列放置皇后
        for col in range(n):
            if is_safe(board, row, col):
                board[row][col] = 1  # 放置皇后
                solve(board, row + 1)  # 递归到下一行
                board[row][col] = 0  # 回溯,移除皇后

    result = []  # 用于存储所有找到的解
    board = [[0] * n for _ in range(n)]  # 初始化棋盘为0(空)
    solve(board, 0)  # 从第0行开始解决N皇后问题
    return result

# 测试代码
n = 8  # 可以设置为任意正整数来表示N皇后的规模
solutions = solve_n_queens(n)
for i, solution in enumerate(solutions):
    print(f"Solution {i + 1}:")
    for line in solution:
        print(line)
    print()

总结

提示:这里对文章进行总结:
例如:以上就是今天要讲的内容,本文简单介绍一种常见的回溯算法。


http://www.kler.cn/a/521241.html

相关文章:

  • Java面试题2025-并发编程基础(多线程、锁、阻塞队列)
  • 第十四讲 JDBC数据库
  • 虹科分享 | 汽车NVH小课堂之听音辨故障
  • Vue.js `setup()` 函数的使用
  • 批量卸载fnm中已经安装的所有版本
  • 研发的立足之本到底是啥?
  • unity. Capsule Collider(胶囊碰撞体)
  • 什么是反向海淘?如何入局反向海淘?
  • 关于圆周率的新认知
  • 寒假学web--day08
  • 第26章 测试驱动开发(TDD)模式详解与 Python 实践
  • K8s运维管理平台 - xkube体验:功能较多
  • [HOT 100] 0015. 三数之和
  • 代码审查中的自动化与AI应用
  • 2025寒假作业
  • C#,入门教程(09)——运算符的基础知识
  • 参照和谐色调为PPT图形设置统一格式的要点
  • CRMEB部署的一些修改
  • 【QT】 控件 -- 显示类
  • Android-okhttp详解
  • Spark Streaming编程基础
  • 基于Java(SSM)+MySQL实现的客户管理系统
  • 3097. 或值至少为 K 的最短子数组 II
  • Direct Preference Optimization (DPO): 一种无需强化学习的语言模型偏好优化方法
  • FPGA同步复位和异步复位
  • Day37:添加元素到列表中