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

回溯算法第一篇(子集树问题【三种思路】、0-1背包问题、最小重量机器设计问题)

目录1. 子集树问题解法一解法二解法三2. 0-1背包问题使用子集树解决3. 最小重量机器设计问题1. 子集树问题子集力扣链接题目描述给你一个整数数组nums数组中的元素互不相同。返回该数组所有可能的子集幂集。解集不能包含重复的子集。你可以按任意顺序返回解集。示例 1输入nums [1,2,3]输出[[],[1],[2],[1,2],[3],[1,3],[2,3],[1,2,3]]示例 2输入nums [0]输出[[],[0]]提示1 nums.length 10-10 nums[i] 10nums中的所有元素互不相同注子集是不能重复的例如{1,2,3}和{3,2,1}是一个子集。解决方案如下解法一算法策略为判断当前位置选还是不选则决策树的形状是二叉树决策树如下注以下代码不是力扣那道题的正确代码需要自行修改一些方法名解法二的代码就可以在力扣运行且通过所有测试import java.util.ArrayList; import java.util.List; //子集的第一种结果叶子结点收集 public class SubsetTest { //设计全局变量 static ListInteger path;//用来临时接受一次自己的情况 static ListListInteger ret;//用来接收全部子集情况 //nums表示需要计算子集的数组 //deep表示第几层也是表示nums数组的第几个元素有两种选择选还是不选 public static void permute(int[] nums, int deep) { //1.初始化 path new ArrayList(); ret new ArrayList(); //2.开始进行回溯算法 dfs(nums, deep); } public static void output() { ret.add(new ArrayList(path)); } public static void dfs(int[] nums, int deep) { //递归出口 if (deep nums.length) { output(); return; } else {//这回溯的核心写成决策树是一颗二叉树因为有两种选择 //1选 path.add(nums[deep]); //进入下一层 dfs(nums, deep 1); //恢复现场移除最后一个元素 path.remove(path.size() - 1); //2不选因为不选没有改变path集合所以不需要恢复现场 dfs(nums, deep 1); } } public static void main(String[] args) { int[] nums {1, 2, 3}; permute(nums, 0); for (int i 0; i ret.size(); i) { System.out.println(ret.get(i)); } } }解法二算法的策略相交于第一种解法有所不同第一种解法是判断当前位置选不选的情况所以决策树的叶子结点才是子集。第二种解法是一棵多叉的决策树是从一个子集的容量问题上来分情况例如子集里面的元素可以是0个、1个、2个也可以是3个。具体如下所示class Solution { ListInteger path;//用来记录一次的子集 ListListInteger ret;//用来记录总的子集情况 public ListListInteger subsets(int[] nums) { //1.初始化 path new ArrayList(); ret new ArrayList(); //2.回溯的核心 dfs(nums, 0); return ret; } //nums需要计算子集的数组 //deep表示当前来到树的第几层 public void dfs(int nums[], int deep) { //因为每一个结点都是我需要的结果所以每一个结点都要收集 ret.add(new ArrayList(path)); //回溯开始 //这里必须从deep开始表示在nums数组中的第几位开始 //只有这样才不会导致重复选取 for (int i deep; i nums.length; i) { path.add(nums[i]); dfs(nums, i 1); //恢复现场 path.remove(path.size() - 1); } } }解法三解法三是在解法一的思路上加上一个boolean数组来判断当前位置选没选决策树如下public class Test10 { static int N 3; static char[] a {a, b, c}; static boolean[] x {false, false, false}; public static void main(String[] args) { backTrack(0); } //回溯的核心 public static void backTrack(int level) { if (level N) { output(); } else { x[level] false;//不选 backTrack(level 1); x[level] true; backTrack(level 1); } } //打印数据 public static void output() { System.out.print({); for (int i 0; i x.length; i) { //如果这个位置是选的话也就是x[i] true就选a[i] if (x[i]) { System.out.print(a[i] ); } } System.out.print(}); System.out.println(); } }2. 0-1背包问题使用子集树解决题目描述你有⼀个背包最多能容纳的体积是V。现在有 n 个物品第 i 个物品的体积为vi价值为wi。1求这个背包⾄多能装多⼤价值的物品2若背包恰好装满求⾄多能装多⼤价值的物品true表示选这物品false表示不选这物品public class Test11 { static int C 30;//背包容量 static int N 3;//三个物品 static int weights[] {16, 15, 15};//重量 static int values[] {45, 25, 25};//价值 static boolean[] x {false, false, false};//作为判断选不选的问题 //保存最大价值 static int maxValuse 0; //回溯核心 //w当前背包所放物品重量和 //v当前背包所放物品价值和 public static void backtrack(int level, int w, int v) { if (level N) { output(v); } else { x[level] false;//不选 backtrack(level 1, w, v); x[level] true;//选 if (legal(w weights[level])) backtrack(level 1, w weights[level], v values[level]); } } //判断当前背包重量是不是合法 public static boolean legal(int w) { return w C; } //v当前的价值 public static void output(int v) { maxValuse Math.max(v, maxValuse); } public static void main(String[] args) { backtrack(0, 0, 0); System.out.println(maxValuse); } }3. 最小重量机器设计问题题目描述设某一机器由 N 个部件组成每一种部件都可以从 M 个不同的供应商处购得。设 W 是从供应商j处购得的部件i的重量, C 是相应的价格。 试设计一个算法给出总价格不超过 D 的最小重量机器设计。解决方案如下public class Test12 { static int N 3;//部件数 static int Suppliers 3;//供应商数 static int D 4;//总价格限制 static int minWeight Integer.MAX_VALUE;//这个变量用来保存最小重量 static int[][] weight {{1, 2, 3}, {3, 2, 1}, {2, 1, 2}};//重量数组 static int[][] value {{1, 2, 3}, {3, 2, 1}, {2, 2, 2}};//价格数组 static int[] str new int[3]; /* false表示选true表示不选 */ //默认值是false //为什么是二维数组呢因为要与w和v二维数组对应 static boolean[][] flag new boolean[3][3]; //打印每个零件的供应商 public static void output() { for (int i 0; i N; i) { for (int j 0; j Suppliers; j) { if (flag[i][j]) str[i] j 1; } } } /* w表示当前的重量 v表示当前的价值 level表示层数0表示选第一个零件、1表示选第二个零件、2表示选第三个零件 */ public static void backtrack(int level, int w, int v) { //能走到这个if肯定是没超过限制重量D if (level N) { int tmp minWeight; minWeight Math.min(minWeight, w); if (tmp ! minWeight) { output(); } } else { //表示从第一个供应商开始选择 for (int i 0; i Suppliers; i) { flag[level][i] true; if (D v value[level][i]) { backtrack(level 1, w weight[level][i], v value[level][i]); } //这个为什么要改为false呢 //方便output方法的实现找到每个零件的供应商 flag[level][i] false; } } } public static void main(String[] args) { backtrack(0, 0, 0); System.out.println(最小重量 minWeight); System.out.print(供应商顺序); for (int i 0; i str.length; i) { System.out.print(str[i] ); } } }

相关文章:

回溯算法第一篇(子集树问题【三种思路】、0-1背包问题、最小重量机器设计问题)

目录 1. 子集树问题 解法一 解法二 解法三 2. 0-1背包问题(使用子集树解决) 3. 最小重量机器设计问题 1. 子集树问题 子集力扣链接 题目描述:给你一个整数数组 nums ,数组中的元素 互不相同 。返回该数组所有可能的子集&am…...

ROS2 Nav2插件化实践:从零构建自定义全局与局部规划器

1. ROS2 Nav2插件化架构深度解析 第一次接触Nav2的插件系统时,我完全被它的灵活性震惊了。这就像乐高积木一样,你可以随意替换导航系统的各个模块,而不用重新编译整个框架。这种设计让我想起小时候玩的插卡游戏机,不同卡带插进去…...

回溯算法第二篇(全排列【基于排列树实现】、旅行售货员问题【基于排列树实现】、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…...