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

回溯算法第二篇(全排列【基于排列树实现】、旅行售货员问题【基于排列树实现】、N皇后【基于子集树实现的】)

目录1. 全排列2. 旅行售货员问题3. N 皇后1. 全排列全排列力扣链接题目描述给定一个不含重复数字的数组nums返回其所有可能的全排列。你可以按任意顺序返回答案。示例 1输入nums [1,2,3]输出[[1,2,3],[1,3,2],[2,1,3],[2,3,1],[3,1,2],[3,2,1]]示例 2输入nums [0,1]输出[[0,1],[1,0]]示例 3输入nums [1]输出[[1]]提示1 nums.length 6-10 nums[i] 10nums中的所有整数互不相同解决方案如下1首先画出决策树① 开始挖了3个空如分别对这3个问号填入数字可以是各个位置可以是1、2或者3。② 如果第一个位置选1那么第二个位置就不能选1了只能选2和3。第一个位置选2或者3也是同理。③ 总结每个位置都是独一无二的在之前不能出现过的。2设计代码① 设计三个全局变量。int[][] ret 一个二维数组用来存储找到的所有排列结果。int[] path 这个变量用来存储已经选择的结果例如一个排列结果是1,2,3那么 path 数组就存储1,2,3。boolean[] check 这个变量用来实现“剪枝”操作。将已经归入 path 数组的元素设置为true标记为已经使用过不能再次选择。② dfs函数回溯算法的核心注意仅需关系某一个结点在干什么事情。例如在第一次选择可以选择三个元素第二次只能选择两个元素第三次只能选择一个元素这就是每一步需要干的事情。③ 细节问题回溯有两点第一点干掉 path 最后一个元素第二点修改check数组。剪枝递归出口遇到叶子结点的时候直接添加结果。class Solution { //定义全局变量 ret 用来收集结果 ListListInteger ret;//用集合来表示二维数组 ListInteger path;//用来保存每一次结果 boolean[] check;//用来表示某个元素是不是已经被选取过 public ListListInteger permute(int[] nums){ //1.初始化 ret new ArrayList(); path new ArrayList(); check new boolean[nums.length]; //2.调用dfs(回溯的核心) dfs(nums); return ret; } public void dfs(int[] nums){ //1.当path的长度和nums的长度一样那么就是将nums的所有元素已经排列在path里 if(nums.length path.size()){ ret.add(new ArrayList(path)); return; } //每一次都有3个选择只是符不符合的问题 for(int i 0;i nums.length;i){ //正面这个元素还没选取 if(check[i] false){ path.add(nums[i]);//将这个元素添加到数组中 /* check还能这么理解如果一个check的元素为true也就是来到树的第一层看上图有层数注解 有两个check的元素为true也就是来到树的第二层 有三个check的元素为true也就是来到树的第三层 */ check[i] true;//将当前位置的元素标记为true表示已经被选取过了 dfs(nums); check[i] false;//将当前位置改为还未选择具体解析看上图 path.remove(path.size() - 1);//移除最后一个元素 } } } }2. 旅行售货员问题题目描述如下图一个售货员从0号城市出发要到1号、2号、3号这几个城市去推销商品已知各城市之间的路程问应该如何选定一条从0号城市出发经过每个城市一遍最后回到0号城市的路线使得总的周游路程最小如下图所示汉密尔顿回路说白了这就是一个求最短汉密尔顿回路的问题。我们先来了解一下汉密尔顿路径汉密尔顿回路还有汉密尔顿图汉密尔顿路径G (V,E)是一个图若G中一条路径通过且仅通过每一个顶点一次称这条路径为哈密顿路径。汉密尔顿回路若G中一个回路通过且仅通过每一个顶点一次称这个环为哈密顿回路。汉密尔顿图若一个图存在哈密顿回路就称为哈密顿图。解决方案如下1首先画出决策树2代码设计① 设计五个全局变量int[][] ret用来保存结果。boolean[] check用来检查哪个城市已经走过了。int[] path用来记录当前的路径。int[] minPath用来保存最短路径的数组int minValue用来记录最小的总路程② 有如下几个方法public void initGraph()对图进行初始化。public boolean legal()对路径进行初始判断是否合法也就是两个城市zhij。import java.util.ArrayList; import java.util.List; public class Test14 { //定义全局变量 ret 用来收集结果 int N 4; int[] nums {0, 1, 2, 3}; ListListInteger ret;//用集合来表示二维数组 ListInteger path;//用来保存每一次结果 boolean[] check;//用来表示某个元素是不是已经被选取过 ListInteger minPath;//用来保存最短的路径进过的城市 int minValue Integer.MAX_VALUE;//用来保存最短路程 int[][] graph new int[N][N];//用来存储图的路径 //为图初始化 public void addEdge(int v1, int v2, int weight) { graph[v1][v2] graph[v2][v1] weight; } public void initGraph() { addEdge(0, 1, 30); addEdge(0, 2, 6); addEdge(0, 3, 4); addEdge(1, 3, 21); addEdge(2, 3, 11); } public ListListInteger permute(int[] nums) { //1.初始化 ret new ArrayList(); path new ArrayList(); path.add(0); check new boolean[nums.length]; minPath new ArrayList(); //2.调用dfs(回溯的核心) dfs(0, nums); return ret; } //判断路径是否合法 public boolean legal(int index, int n) { int v1 path.get(n);//得到当前城市的前一个城市的数组下标 int v2 index;//当前城市的数组下标 return graph[v1][v2] ! 0 check[index] false; } //判断最后一个城市到达0号城市是否有路径 public boolean legalLast() { int v1 path.get(0); int v2 path.get(path.size() - 1); return graph[v1][v2] ! 0; } public void dfs(int n, int[] nums) { //证明到达了0号城市之前的最后一个城市 if (n nums.length - 1) { //判断最后一个城市到达0号城市是否有路径 if (legalLast()) { ListInteger tmp new ArrayList(); for (int i 0; i path.size(); i) { tmp.add(path.get(i)); } path.add(0); tmp.add(path.get(path.size() - 1)); ret.add(new ArrayList(tmp)); int tmpRoad 0; // tmpRoad 计算本次路程的总和然后和minValue进行比较 for (int i 1; i path.size(); i) { int v1 path.get(i - 1); int v2 path.get(i); tmpRoad graph[v1][v2]; } //保留上次的最短路径 int minTmp minValue; minValue Math.min(minValue, tmpRoad); //如果最短路程和有改变就将最短路程保留到minPath中 if (minValue ! minTmp) { for (int i 0; i path.size(); i) { minPath.add(path.get(i)); } } } }else{ //开始匹配 //从1号城市开始 for (int i 1; i nums.length; i) { if (legal(i, n)) { check[i] true; path.add(i); dfs(n 1, nums); //恢复现场 check[i] false; path.remove(n); } } } } public static void main(String[] args) { Test14 test14 new Test14(); test14.initGraph(); test14.permute(test14.nums); System.out.println(test14.minValue); for (int i 0; i test14.minPath.size(); i) { System.out.print(test14.minPath.get(i) ); } } }3. N 皇后基于子集树实现N 皇后力扣链接题目描述按照国际象棋的规则皇后可以攻击与之处在同一行或同一列或同一斜线上的棋子。n 皇后问题研究的是如何将n个皇后放置在n×n的棋盘上并且使皇后彼此之间不能相互攻击。给你一个整数n返回所有不同的n皇后问题的解决方案。每一种解法包含一个不同的n 皇后问题的棋子放置方案该方案中Q和.分别代表了皇后和空位。解决方案如下1算法思路⾸先我们在棋盘第⼀⾏放置第⼀个皇后然后遍历棋盘的第⼆⾏在可⾏的位置放置第⼆个皇后然后再遍历第三⾏在可⾏的位置放置第三个皇后以此类推直到放置了 n 个皇后为⽌。我们需要⽤⼀个数组来记录每⼀⾏放置的皇后的列数。在每⼀⾏中我们尝试放置⼀个皇后并检查是否会和前⾯已经放置的皇后冲突。如果没有冲突我们就继续递归地放置下⼀⾏的皇后直到所有的皇后都放置完毕然后把这个⽅案记录下来。在检查皇后是否冲突时我们可以⽤⼀个数组来记录每⼀列是否已经放置了皇后并检查当前要放置的皇后是否会和已经放置的皇后冲突。对于对⻆线我们可以⽤两个数组来记录从左上⻆到右下⻆的每⼀条对⻆线上是否已经放置了皇后以及从右上⻆到左下⻆的每⼀条对⻆线上是否已经放置了皇后。对于对⻆线是否冲突的判断可以通过以下流程解决1. 从左上到右下相同对⻆线的⾏列之差相同。2. 从右上到左下相同对⻆线的⾏列之和相同。因此我们需要创建⽤于存储解决⽅案的⼆维字符串数组ret⽤于存储每个皇后的位置的⼀维整数数组? queens 以及⽤于记录每⼀列和对⻆线上是否已经有皇后的布尔型数组columns 、diagonals1 和 diagonals2 。2 递归函数流程如下① 结束条件如果 row 等于 n 则表⽰已经找到⼀组解决⽅案此时将每个皇后的位置存储到字符串数组 path 中并将 path 存储到 ret 数组中然后返回② 枚举当前⾏的每⼀列判断该列、两个对⻆线上是否已经有皇后a. 如果有皇后则继续枚举下⼀列b. 否则在该位置放置皇后并将 columns 、diagonals1 和 diagonals2 对应的位置设为 true 表⽰该列和对⻆线上已经有皇后递归调⽤ dfs 函数搜索下⼀⾏的皇后位置。如果该⽅案递归结束则在回溯时需要将 columns 、 diagonals1 和 diagonals2 对应的位置设为 false 然后继续枚举下⼀列。class Solution { //1.定义全局变量 /* column用来判断列的 diagonals1用来判断正对角线 diagonals2用来判断反对角线 */ boolean[] columns, diagonals1, diagonals2; //结果收集的二维数组 ListListString ret; //收集本次皇后位置的数组因为棋盘是二维的所以path是二维数组 char[][] path; //表示棋盘的行或者列 int n; //如果要得到八皇后的结果只需要调用这个方法时传入8即可 public ListListString solveNQueens(int _n) { //2.初始化 n _n; columns new boolean[n]; diagonals1 new boolean[2 * n]; diagonals2 new boolean[2 * n]; ret new ArrayList(); path new char[n][n]; //把path的所有位置先该为. for (int i 0; i n; i) { Arrays.fill(path[i], .); } //开始回溯算法的核心部分 dfs(0);//从第一行开始 return ret; } public void dfs(int row) { //如果到了棋盘的最后一行了证明本次皇后们的位置是合法的 if (row n) { //添加结果 ListString tmp new ArrayList(); for (int i 0; i n; i) { tmp.add(new String(path[i])); } ret.add(new ArrayList(tmp)); } //开始匹配 for (int col 0; col n; col) { //判断能不能放 if (columns[col] false diagonals1[col - row n] false diagonals2[col row] false) { path[row][col] Q; columns[col] diagonals1[col - row n] diagonals2[col row] true; //寻找下一行 dfs(row 1); //恢复现场 path[row][col] .; columns[col] diagonals1[col - row n] diagonals2[col row] false; } } } }

相关文章:

回溯算法第二篇(全排列【基于排列树实现】、旅行售货员问题【基于排列树实现】、N皇后【基于子集树实现的】)

目录 1. 全排列 2. 旅行售货员问题 3. N 皇后 1. 全排列 全排列力扣链接 题目描述:给定一个不含重复数字的数组 nums ,返回其 所有可能的全排列 。你可以 按任意顺序 返回答案。 示例 1: 输入:nums [1,2,3] 输出&#xff1…...

PPTist:重新定义浏览器端演示文稿编辑的技术架构与商业价值

PPTist:重新定义浏览器端演示文稿编辑的技术架构与商业价值 【免费下载链接】PPTist PowerPoint-ist(/pauəpɔintist/), An online presentation application that replicates most of the commonly used features of MS PowerPoint, allowi…...

Shadcn-Vue完整指南:Vue开发者如何用开源代码构建专属组件库

Shadcn-Vue完整指南:Vue开发者如何用开源代码构建专属组件库 【免费下载链接】shadcn-vue Vue port of shadcn-ui 项目地址: https://gitcode.com/gh_mirrors/sh/shadcn-vue 你是否厌倦了传统UI库的限制?是否想要一个既美观又完全可控制的Vue组件…...

Python 编程最佳实践:`is` 与 `==` 的区别,以及为什么它可能在生产环境中“偷偷”酿成事故

Python 编程最佳实践:is 与 的区别,以及为什么它可能在生产环境中“偷偷”酿成事故 📌 引言:一个看似微小的语法选择,却能决定系统稳定性 客观来看,Python 作为“胶水语言”在 Web 开发、数据科学、自动…...

DANet性能优化实战:多GPU训练与推理加速技巧

DANet性能优化实战:多GPU训练与推理加速技巧 【免费下载链接】DANet Dual Attention Network for Scene Segmentation (CVPR2019) 项目地址: https://gitcode.com/gh_mirrors/da/DANet DANet(Dual Attention Network for Scene Segmentation&…...

如何快速构建私有化大语言模型:ggml与llama.cpp的终极集成指南

如何快速构建私有化大语言模型:ggml与llama.cpp的终极集成指南 【免费下载链接】ggml Tensor library for machine learning 项目地址: https://gitcode.com/GitHub_Trending/gg/ggml 在当今AI驱动的时代,构建私有化大语言模型已成为企业和开发者…...

身份管理化技术用户生命周期与权限回收

身份管理化技术:用户生命周期与权限回收的智能治理 在数字化时代,企业面临用户身份与权限管理的复杂挑战。身份管理化技术通过自动化流程,实现从用户入职到离职的全生命周期管控,确保权限分配精准、回收及时,成为企业…...

告别CANoe黑盒:用Python的can库+cantools手把手解析BLF日志(附完整代码)

开源CAN数据分析实战:Python替代方案解析BLF日志全流程 在汽车电子和工业控制领域,CAN总线数据的采集与分析是开发调试的关键环节。Vector公司的CANoe长期以来是行业标准工具,但其商业授权费用让许多个人开发者和初创团队望而却步。幸运的是&…...

TypeScript图算法教程:Dijkstra、Bellman-Ford等最短路径算法实战

TypeScript图算法教程:Dijkstra、Bellman-Ford等最短路径算法实战 【免费下载链接】TypeScript Algorithms and Data Structures implemented in TypeScript for beginners, following best practices. 项目地址: https://gitcode.com/gh_mirrors/type/TypeScript…...

如何在Vibe Kanban中创建和使用自定义标签:提升任务管理效率的完整指南

如何在Vibe Kanban中创建和使用自定义标签:提升任务管理效率的完整指南 【免费下载链接】vibe-kanban Get 10X more out of Claude Code, Codex or any coding agent 项目地址: https://gitcode.com/GitHub_Trending/vi/vibe-kanban Vibe Kanban是一款高效的…...

终极指南:dots.ocr高级配置 - 自定义像素范围和预处理参数的完整教程

终极指南:dots.ocr高级配置 - 自定义像素范围和预处理参数的完整教程 【免费下载链接】dots.ocr Multilingual Document Layout Parsing in a Single Vision-Language Model 项目地址: https://gitcode.com/gh_mirrors/do/dots.ocr dots.ocr是一款强大的多语…...

深入解析YOLOv8检测头:从DFL原理到实现细节

1. YOLOv8检测头的核心创新:DFL设计原理 第一次看到YOLOv8的检测头代码时,我盯着那个reg_max16的参数看了好久。这个看似简单的数字背后,藏着YOLOv8在目标检测精度上突飞猛进的秘密武器——Distribution Focal Loss(DFL&#xff0…...

Windows 11性能优化革命:Tiny11Builder如何让老旧硬件重获新生

Windows 11性能优化革命:Tiny11Builder如何让老旧硬件重获新生 【免费下载链接】tiny11builder Scripts to build a trimmed-down Windows 11 image. 项目地址: https://gitcode.com/GitHub_Trending/ti/tiny11builder 在数字化转型加速的今天,企…...

如何用pyvideotrans实现视频翻译与AI配音:一站式跨语言内容创作指南

如何用pyvideotrans实现视频翻译与AI配音:一站式跨语言内容创作指南 【免费下载链接】pyvideotrans Translate the video from one language to another and embed dubbing & subtitles. 项目地址: https://gitcode.com/gh_mirrors/py/pyvideotrans 在全…...

PPTist:如何在5分钟内创建专业演示文稿?这个开源工具让你告别传统PPT软件

PPTist:如何在5分钟内创建专业演示文稿?这个开源工具让你告别传统PPT软件 【免费下载链接】PPTist PowerPoint-ist(/pauəpɔintist/), An online presentation application that replicates most of the commonly used features …...

手把手教你用QGIS加载GLC_FCS30-2020土地覆盖数据(附配色方案与精度验证)

手把手教你用QGIS加载GLC_FCS30-2020土地覆盖数据(附配色方案与精度验证) 第一次打开GLC_FCS30-2020数据集时,面对30种地类分类和庞大的GeoTIFF文件,大多数GIS从业者都会陷入短暂的迷茫——这份数据究竟该如何快速上手&#xff1f…...

5分钟掌握跨平台歌词提取:新手完整指南

5分钟掌握跨平台歌词提取:新手完整指南 【免费下载链接】163MusicLyrics 云音乐歌词获取处理工具【网易云、QQ音乐】 项目地址: https://gitcode.com/GitHub_Trending/16/163MusicLyrics 你是否曾经在深夜听歌时,突然想保存某句触动人心的歌词&am…...

Harness Engineering与Context Engineering:差异与协同

Harness Engineering与Context Engineering:差异与协同 副标题:从「如何用好提示词」到「如何把大模型能力彻底工程化落地」的全链路实践体系 第一部分:引言与基础 1.1 摘要/引言 问题陈述 如果你是一名刚接触大语言模型(LLM)应用开发的开发者,可能会遇到这样的困境:…...

Jitsi Desktop:开源通信新选择,解锁多协议聊天体验

Jitsi Desktop:开源通信新选择,解锁多协议聊天体验随着远程工作和在线交流的日益频繁,一款强大且灵活的通信工具变得尤为重要。今天,我们为你揭开Jitsi Desktop的神秘面纱——这是一款功能全面、自由开放源代码的音视频及文本聊天…...

如何实现微信聊天记录永久备份:3步掌握本地数据自主权终极指南

如何实现微信聊天记录永久备份:3步掌握本地数据自主权终极指南 【免费下载链接】WeChatMsg 提取微信聊天记录,将其导出成HTML、Word、CSV文档永久保存,对聊天记录进行分析生成年度聊天报告 项目地址: https://gitcode.com/GitHub_Trending/…...

如何快速掌握LyricsX:Mac桌面歌词显示的终极解决方案

如何快速掌握LyricsX:Mac桌面歌词显示的终极解决方案 【免费下载链接】Lyrics Swift-based iTunes plug-in to display lyrics on the desktop. 项目地址: https://gitcode.com/gh_mirrors/lyr/Lyrics LyricsX是一款专为Mac用户设计的免费开源iTunes歌词插件…...

在Ubuntu20.04上搭建Gazebo仿真环境:从零开始运行ROS小车模型

1. 环境准备:Ubuntu20.04与ROS基础配置 在开始搭建Gazebo仿真环境之前,我们需要确保系统基础环境已经就绪。Ubuntu20.04作为长期支持版本(LTS),是ROS Noetic的官方推荐系统。我实测过多个ROS版本组合,这个搭…...

保姆级教程:用Python和Tacotron2+WaveGlow快速搭建你的第一个AI语音合成Demo

从零构建AI语音合成系统:Tacotron2与WaveGlow实战指南 语音合成技术正以前所未有的速度渗透到智能助手、有声读物和虚拟主播等场景中。本教程将手把手带你搭建一个完整的TTS(Text-To-Speech)系统,使用业界主流的Tacotron2作为声学…...

【实战指南】同花顺WEB下单接口API:从零搭建个人量化交易系统

1. 为什么选择同花顺WEB下单接口 很多刚接触量化交易的朋友都会问:市面上有那么多专业交易软件,为什么要用同花顺的WEB接口?我刚开始做量化时也纠结过这个问题,后来发现同花顺这套方案有几个特别实在的优势。 首先是最现实的成本问…...

Revezone 自定义字体完全教程:让你的白板作品更具个性化

Revezone 自定义字体完全教程:让你的白板作品更具个性化 【免费下载链接】revezone A lightweight local-first graphic-centric productivity tool to build your second brain. Supporting Excalidraw/Tldraw whiteboard and notion-like note. 一款以图形为中心、…...

如何3步解锁Cursor Pro高级功能:开源工具完整指南

如何3步解锁Cursor Pro高级功能:开源工具完整指南 【免费下载链接】cursor-free-vip [Support 0.45](Multi Language 多语言)自动注册 Cursor Ai ,自动重置机器ID , 免费升级使用Pro 功能: Youve reached your trial r…...

视频字幕制作革命:VideoSrt让语音识别字幕生成效率提升500%

视频字幕制作革命:VideoSrt让语音识别字幕生成效率提升500% 【免费下载链接】video-srt-windows 这是一个可以识别视频语音自动生成字幕SRT文件的开源 Windows-GUI 软件工具。 项目地址: https://gitcode.com/gh_mirrors/vi/video-srt-windows 还在为视频字幕…...

揭秘ESPectre运动检测算法:MVS与NBVI的数学之美

揭秘ESPectre运动检测算法:MVS与NBVI的数学之美 【免费下载链接】espectre 🛜 ESPectre 👻 - Motion detection system based on Wi-Fi spectre analysis (CSI), with Home Assistant integration. 项目地址: https://gitcode.com/gh_mirro…...

从视频到3D模型:用COLMAP+3D Gaussian Splatting快速重建物体,保姆级数据处理教程

从视频到3D模型:用COLMAP3D Gaussian Splatting快速重建物体,保姆级数据处理教程 在数字内容创作领域,三维重建技术正以前所未有的速度改变着我们记录和呈现世界的方式。想象一下,用手机拍摄一段简单的环绕视频,几小时…...

JeecgBoot开发环境一站式配置指南:从零搭建到高效运行

1. 环境准备:从零搭建JeecgBoot开发环境 第一次接触JeecgBoot时,我被它"企业级低代码平台"的定位吸引,但真正开始配置开发环境时却踩了不少坑。这里分享我总结的一站式配置方案,帮你避开那些让我熬夜的雷区。 开发Jeecg…...