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

网站域名可以改么免费网站模板库

网站域名可以改么,免费网站模板库,网络营销方案论文,本网站只做信息展示不提供在线交易在学习和使用回溯算法解决问题时&#xff0c;我们经常会遇到需要维护一个结果列表&#xff0c;例如所有可能的子集、组合或排列。 这个结果列表通常是一个 List<List<Integer>>&#xff0c;其中内部的 List<Integer> 代表一个具体的解。 然而&#xff0c;在…

在学习和使用回溯算法解决问题时,我们经常会遇到需要维护一个结果列表,例如所有可能的子集、组合或排列。 这个结果列表通常是一个 List<List<Integer>>,其中内部的 List<Integer> 代表一个具体的解。

然而,在构建这些内部的 List<Integer> 时,我们应该使用 List 接口还是 ArrayList 类呢? 这个问题看似简单,但背后隐藏着一个关于深拷贝和浅拷贝的重要概念,它直接影响到回溯算法的正确性。

问题重现:回溯算法中的陷阱

让我们考虑一个简单的例子:使用回溯算法找到一个数组的所有子集。 一个常见的实现方式如下:

import java.util.ArrayList;
import java.util.List;public class Subsets {public static List<List<Integer>> subsets(int[] nums) {List<List<Integer>> res = new ArrayList<>();backtrack(nums, 0, new ArrayList<>(), res);return res;}private static void backtrack(int[] nums, int index, List<Integer> currentSubset, List<List<Integer>> res) {// 基本情况:将当前子集添加到结果列表res.add(currentSubset); // 潜在的问题!// 递归探索for (int i = index; i < nums.length; i++) {currentSubset.add(nums[i]); // 选择backtrack(nums, i + 1, currentSubset, res);currentSubset.remove(currentSubset.size() - 1); // 撤销选择 (回溯)}}public static void main(String[] args) {int[] nums = {1, 2, 3};List<List<Integer>> allSubsets = subsets(nums);System.out.println(allSubsets);}
}

展开

这段代码看起来很合理,但如果你运行它,你会发现结果是错误的! 例如,对于输入 [1, 2, 3],你可能会得到类似 [[], [], [], [], [], [], [], []] 的结果,而不是预期的 [[], [1], [2], [1, 2], [3], [1, 3], [2, 3], [1, 2, 3]]

问题出在哪里?

问题在于这行代码:

res.add(currentSubset);

这里,我们直接将 currentSubset 添加到 res 中,而没有进行任何拷贝。 这意味着 res 中的所有元素都指向同一个 currentSubset 对象。 当我们在回溯过程中修改 currentSubset 时,res 中的所有元素都会受到影响,最终导致错误的结果。

深拷贝的必要性

为了解决这个问题,我们需要对 currentSubset 进行深拷贝,然后再将其添加到 res 中。 深拷贝会创建一个新的 ArrayList 对象,并将 currentSubset 中的所有元素复制到这个新的 ArrayList 中。 这样,res 中的每个元素都将指向一个独立的列表,而对 currentSubset 的修改不会影响到 res 中的其他元素。

正确的代码如下:

import java.util.ArrayList;
import java.util.List;public class Subsets {public static List<List<Integer>> subsets(int[] nums) {List<List<Integer>> res = new ArrayList<>();backtrack(nums, 0, new ArrayList<>(), res);return res;}private static void backtrack(int[] nums, int index, List<Integer> currentSubset, List<List<Integer>> res) {// 基本情况:将当前子集添加到结果列表res.add(new ArrayList<>(currentSubset)); // 深拷贝!// 递归探索for (int i = index; i < nums.length; i++) {currentSubset.add(nums[i]); // 选择backtrack(nums, i + 1, currentSubset, res);currentSubset.remove(currentSubset.size() - 1); // 撤销选择 (回溯)}}public static void main(String[] args) {int[] nums = {1, 2, 3};List<List<Integer>> allSubsets = subsets(nums);System.out.println(allSubsets);}
}

展开

现在,res.add(new ArrayList<>(currentSubset)) 创建了一个 currentSubset 的副本,并将这个副本添加到 res 中。 这样,res 中的每个元素都指向一个独立的列表,结果就是正确的。

http://www.dtcms.com/wzjs/54025.html

相关文章:

  • 免费创建网站带咨询的百度站长平台电脑版
  • 海口制作网站公司谷歌seo最好的公司
  • 网站开发流程的认识如何提升网站搜索排名
  • 鄂州做网站的公司销售课程培训视频教程
  • 滁州网站开发怎么注册域名网址
  • 河北网站制作公司地址怎么设计网站
  • 课程分销的网站怎么做免费发广告的软件
  • 在网站建设中注意的要点什么是网站优化
  • 建设公司网站源码苏州百度代理公司
  • 门户网站系统建设招标文件营销网站都有哪些
  • 南昌做网站流程搜狗输入法下载安装
  • 厦门专业做网站百度广告位价格
  • 帝国网站网站手机版怎么做站内免费推广有哪些
  • 泸州百度做网站联系云南网络营销公司
  • 化妆品公司网站源码最近国际新闻大事
  • 2016优秀网站设计海外网络推广方案
  • 国外著名的网站设计公司seo外链优化方法
  • 用.cc做网站官网可以吗开鲁网站seo不用下载
  • 中铁建设门户网登录咋进不去了南昌seo网站推广
  • 辽宁建设工程信息网登录不上去南宁seo排名优化
  • 找网站公司做网站国际军事新闻最新消息视频
  • 网站跳出率高怎么办海外seo推广公司
  • 九一果冻制品厂最新电视沧州网站推广优化
  • 手机版oaseo免费推广
  • 秦皇岛网站建设新闻热点素材
  • 自己有服务器怎么搭建网站网页百度网盘
  • 公司网站的服务器网站模板哪家好
  • 北京高端网站建设费用接广告推广
  • 长沙专业做网站公司江西省seo
  • 网站流量通道短视频营销成功案例