算法学习7——回溯算法

什么是回溯算法?

回溯算法是一种试探性搜索算法,通过递归的方式逐步构建解决方案,并在发现当前路径不满足条件时回退到上一步。回溯算法特别适用于组合优化问题,如全排列、组合、子集和图的着色问题等。

回溯算法的特点

  1. 递归:通过递归调用函数逐步构建解。
  2. 回溯:当发现当前路径不满足条件时,回退到上一步继续尝试其他可能性。
  3. 剪枝:通过提前终止不必要的搜索,提高算法效率。

经典例子及其Python实现

1. N皇后问题

问题描述:在N×N的棋盘上放置N个皇后,使得任意两个皇后不在同一行、同一列或同一对角线上。

实现过程

  1. 逐行放置皇后,尝试每一列。
  2. 判断是否满足条件,若满足则继续下一行,若不满足则回退。
  3. 直到所有行都放置完毕,输出解。

Python代码

def solve_n_queens(n):def is_safe(board, row, col):for i in range(row):if board[i] == col or abs(board[i] - col) == row - i:return Falsereturn Truedef solve(board, row):if row == n:result.append(board[:])returnfor col in range(n):if is_safe(board, row, col):board[row] = colsolve(board, row + 1)board[row] = -1result = []board = [-1] * nsolve(board, 0)return result# 示例
n = 4
solutions = solve_n_queens(n)
for sol in solutions:print(sol)
2. 全排列问题

问题描述:给定一个数组,求出所有可能的排列。

实现过程

  1. 逐个交换数组元素,生成不同排列。
  2. 递归地继续生成排列。
  3. 回退并交换回原来的顺序。

Python代码

def permute(nums):def backtrack(start):if start == len(nums):result.append(nums[:])returnfor i in range(start, len(nums)):nums[start], nums[i] = nums[i], nums[start]backtrack(start + 1)nums[start], nums[i] = nums[i], nums[start]result = []backtrack(0)return result# 示例
nums = [1, 2, 3]
print(permute(nums))
3. 子集和问题

问题描述:给定一个集合,求出所有可能的子集。

实现过程

  1. 递归生成子集。
  2. 每次选择是否包含当前元素。
  3. 递归继续生成下一个元素的子集。

Python代码

def subsets(nums):def backtrack(start, path):result.append(path[:])for i in range(start, len(nums)):path.append(nums[i])backtrack(i + 1, path)path.pop()result = []backtrack(0, [])return result# 示例
nums = [1, 2, 3]
print(subsets(nums))
4. 骑士巡游问题

问题描述:在N×N的棋盘上,骑士从某一位置出发,经过每个方格一次且仅一次。

实现过程

  1. 递归尝试每一步。
  2. 判断是否满足骑士走法且未访问过该方格。
  3. 若满足则继续下一步,否则回退。

Python代码

def solve_knights_tour(n):def is_safe(x, y, board):return 0 <= x < n and 0 <= y < n and board[x][y] == -1def solve(x, y, movei, board, x_move, y_move):if movei == n * n:return Truefor k in range(8):next_x, next_y = x + x_move[k], y + y_move[k]if is_safe(next_x, next_y, board):board[next_x][next_y] = moveiif solve(next_x, next_y, movei + 1, board, x_move, y_move):return Trueboard[next_x][next_y] = -1return Falseboard = [[-1 for _ in range(n)] for _ in range(n)]x_move = [2, 1, -1, -2, -2, -1, 1, 2]y_move = [1, 2, 2, 1, -1, -2, -2, -1]board[0][0] = 0if solve(0, 0, 1, board, x_move, y_move):return boardelse:return "No solution exists"# 示例
n = 5
solution = solve_knights_tour(n)
for row in solution:print(row)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/48471.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

cdh社区版免费替代方案。

免费的话&#xff0c;现在国产化的东西其实也还可以&#xff0c;而且国家在追求信创&#xff08;信息科技创新&#xff09;嘛。只有用的人多了&#xff0c;用的公司多了&#xff0c;国产的才有钱。才会发展的更好&#xff0c;良性循环。恶性的就是操作系统&#xff0c;大家都在…

Unity | Shader基础知识(第十九集:顶点着色器的进一步理解-易错点讲解)

目录 一、前言 二、网格 三、方法UnityObjectToClipPos 四、顶点着色器和片元着色器的POSITION 五、作者的碎碎念 一、前言 之前我们简单讲解过顶点着色器&#xff0c;也简单讲解了表面着色器&#xff0c;并且一起做了一些案例&#xff0c;因为顶点着色器本身是更自由一些…

RT-Thread必考面试题及参考答案

目录 RT-Thread操作系统的核心架构是什么? RT-Thread支持哪些微处理器架构? RT-Thread中任务调度的基本原则是什么? 如何在RT-Thread中创建一个新的线程? RT-Thread中的线程优先级如何影响调度? RT-Thread中的信号量和互斥锁有何区别? 描述一下RT-Thread中消息队列…

【Git多人协作开发】不同的分支下的多人协作开发模式

目录 0.前言背景 1.开发者1☞完成准备工作&协作开发 1.1查看分支情况 1.2创建本地分支feature-1 1.3三板斧 1.4push推本地分支feature-1到远程仓库 2.开发者2☞完成准备工作&协作开发 2.1创建本地分支feature-2 2.2三板斧 2.2push推送本地feature-2到远程仓库…

Sprong Boot学习|使用 guava-retrying 实现重试

背景 后端业务系统可能会在接口调用失败、网络拥塞超时、任务执行失败、系统错误等异常情况出现的时候进行重试操作&#xff0c;然而不同的场景对于重试的延迟间隔&#xff0c;频次等会有不同的要求&#xff0c;如果自己编排重试代码会比较繁琐&#xff0c;使用 guava-retryin…

LeetCode:合并2个有序数组(C语言)

1、2个非递减排序的整数数组nums1和nums2&#xff0c;2个整数m和n&#xff0c;代表nums1和nums2中的元素个数。合并nums2到nums1&#xff0c;合并后的数组也进行非递减排序 2、示例 示例 1&#xff1a; 输入&#xff1a;nums1 [1,2,3,0,0,0], m 3, nums2 [2,5,6], n 3 输出…

springSecurity学习之springSecurity web如何取得用户信息

web如何取得用户信息 之前说过SecurityContextHolder默认使用的是ThreadLocal来进行存储的&#xff0c;而且每次都会清除&#xff0c;但是web每次请求都会验证用户权限&#xff0c;这是如何做到的呢&#xff1f; 这是通过SecurityContextPersistenceFilter来实现的&#xff0…

FineBI连接MySQL5.7

一、在FineBI系统管理中&#xff0c;点击【新建数据库连接】 选择MySQL数据库 配置数据库连接&#xff0c;如下&#xff0c;其中数据库名称就是需要连接的目标数据库

《昇思 25 天学习打卡营第 21 天 | LSTM+CRF序列标注模型实现 》

《昇思 25 天学习打卡营第 21 天 | LSTMCRF序列标注模型实现 》 活动地址&#xff1a;https://xihe.mindspore.cn/events/mindspore-training-camp 签名&#xff1a;Sam9029 序列标注问题概述 序列标注是信息抽取中的一个关键任务&#xff0c;包括分词、词性标注、命名实体识别…

【通信协议-RTCM】MSM语句(2) - RINEXMSM7语句总结(重要!自动化开发计算卫星状态常用)

注释&#xff1a; 在工作中主要负责的是RTCM-MSM7语句相关开发工作&#xff0c;所以主要介绍的就是MSM7语句相关内容 1. 相位校准参考信号 2. MSM1、MSM2、MSM3、MSM4、MSM5、MSM6和MSM7的消息头内容 DATA FIELDDF NUMBERDATA TYPENO. OF BITSNOTES Message Number - 消息编…

四、Object 通⽤⽅法

Object是Java中所有类的基类&#xff0c;是最顶级的父类。在Java中&#xff0c;每个类都直接或间接地继承自Object类&#xff0c;即使没有显式地声明继承关系&#xff0c;Java也会自动为每个类添加extends Object。这意味着&#xff0c;Object类中定义的方法可以被所有Java类使…

React组件定义

一、定义 组件是是构建用户界面&#xff08;UI&#xff09;的基础&#xff0c;它可以是一个输入框、按钮、也可以是一整个页面。组件可以分为以下2种类型&#xff1a; 1、函数组件&#xff08;Functional Components&#xff09; 顾名思义就是用来函数定义的组件&#xff0c…

DML数据操作语句和基本的DQL语句

一、MySQL对数据的增删改查 1.DML语句 1.1 增加数据(INSERT) insert into 表名 (字段名,字段名,...字段名) values/value (值,值,...值) 1.1.1 新增数据的具体实现 &#xff08;1&#xff09;全字段的插入 方式一&#xff1a; insert into student (sid,sname,birthday,ssex,…

C++的智能指针

说实话以前用这个很少&#xff0c;一个指针打天下&#xff0c;不过都智能了&#xff0c;分配了就不管了&#xff0c;想来还是很方便。。。 1 unique_ptr 代码示例&#xff1a; #include <iostream> #include <memory>class MyClass { public:MyClass() { std::c…

【2024最新华为OD-C/D卷试题汇总】[支持在线评测] 开源项目热度排行榜(100分) - 三语言AC题解(Python/Java/Cpp)

🍭 大家好这里是清隆Coding ,一枚热爱算法的程序员 ✨ 本系列打算持续跟新华为OD-C/D卷的三语言AC题解 👏 感谢大家的订阅➕ 和 喜欢💗 🍿 最新华为OD机试D卷目录,全、新、准,题目覆盖率达 95% 以上,支持题目在线评测,专栏文章质量平均 93 分 最新华为OD机试目录…

Linux网络-配置IP

作者介绍&#xff1a;简历上没有一个精通的运维工程师。希望大家多多关注作者&#xff0c;下面的思维导图也是预计更新的内容和当前进度(不定时更新)。 本来IP配置应该放在Linux安装完成的就要配置的&#xff0c;但是由于那个时候对Linux不怎么熟悉&#xff0c;所以单独列了一个…

JVM系列(一) -浅谈虚拟机的成长史

一、摘要 众所周知&#xff0c;Java 经过多年的发展&#xff0c;已经从一门单纯的计算机编程语言&#xff0c;发展成了一套成熟的软件解决方案。从互联网到企业平台&#xff0c;Java 是目前使用最广泛的编程语言。 以下这段内容是来自 Java 的官方介绍&#xff01; 从笔记本电…

图片变更检测

20240723 By wdhuag 目录 前言&#xff1a; 参考&#xff1a; 文件监控&#xff1a; 图片占用问题&#xff1a; 源码&#xff1a; 前言&#xff1a; 由于第三方图像处理软件不能回传图片&#xff08;正常都能做&#xff0c;这里只是不想做&#xff09;&#xff0c;只能在…

Postman接口测试工具的使用

一、postman简介 Postman是一款功能强大的网页调试与发送网页HTTP请求的Chrome插件。作用&#xff1a;常用于进行接口测试。不需要安装。 特征&#xff1a;简单&#xff0c;实用&#xff0c;美观&#xff0c;大方。 二、Postman接口测试工具的使用 Postman不需要安…

Emacs vs IDE:用Emacs写程序真的更方便吗?

前言 在程序员的世界里&#xff0c;选择合适的开发工具至关重要。Emacs作为一种历史悠久且功能强大的文本编辑器&#xff0c;因其灵活性和扩展性吸引了许多程序员。那么&#xff0c;Emacs究竟有哪些优点&#xff1f;用Emacs写程序真的比使用现代IDE更方便吗&#xff1f;本文将…