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

网站开发 设置背景图片房山新农村建设网站

网站开发 设置背景图片,房山新农村建设网站,优惠券网站做淘客违规吗,营销咨询公司排名前十#LeetCode 491. Non-decreasing Subsequences #LeetCode 491. 视频讲解:回溯算法精讲,树层去重与树枝去重 | LeetCode:491.递增子序列_哔哩哔哩_bilibili 首先,本题不能考虑首先对数组排序,排序会导致数组直接变为一个…

#LeetCode 491. Non-decreasing Subsequences

#LeetCode 491. 视频讲解:回溯算法精讲,树层去重与树枝去重 | LeetCode:491.递增子序列_哔哩哔哩_bilibili

首先,本题不能考虑首先对数组排序,排序会导致数组直接变为一个递增的序列。本题依然是一个组合问题,所以无序,i 在for loop中依然是从startIndex 开始。与之前的去重逻辑不同,每一层会有一个uset 变量,是记录本层元素是否重复使用,新的一层uset都会重新定义,不是之前去重那样的全局变量,同样回溯的时候也不需要删除元素,也是在树层去重。

代码:

class Solution {List<List<Integer>> result = new ArrayList<>();LinkedList<Integer> path = new LinkedList<>();public List<List<Integer>> findSubsequences(int[] nums) {backtracking(nums, 0);return result;}public void backtracking(int[] nums, int startIndex) {if (startIndex > nums.length) {return;}if (path.size() > 1) {result.add(new ArrayList<>(path));}HashSet<Integer> uset = new HashSet<>();for (int i = startIndex; i < nums.length; i++) {if (!path.isEmpty() && path.getLast() > nums[i] || uset.contains(nums[i])) {continue;}uset.add(nums[i]);path.addLast(nums[i]);backtracking(nums, i + 1);path.removeLast();}}
}

#LeetCode 46. Permutations

#LeetCode 46. 视频讲解:组合与排列的区别,回溯算法求解的时候,有何不同?| LeetCode:46.全排列_哔哩哔哩_bilibili

与之前的组合问题不同的地方在于,排列是有序的,[1, 2] 和[2, 1] 是不同的,如果用used 数组,那么在for loop 遍历的时候也是通过used 数组的标记,来判断下一次取具体哪一个数字。

回溯方法代码:

class Solution {List<List<Integer>> result = new ArrayList<>();LinkedList<Integer> path = new LinkedList<>();public List<List<Integer>> permute(int[] nums) {boolean[] used = new boolean[nums.length];Arrays.fill(used, false);backtracking(nums, used);return result;}public void backtracking(int[] nums, boolean[] used) {if (path.size() == nums.length) {result.add(new LinkedList<>(path));return;}for (int i = 0; i < nums.length; i++) {if (used[i]) {continue;}used[i] = true;path.addLast(nums[i]);backtracking(nums, used);used[i] = false;path.removeLast();}}
}

#LeetCode 47. Permutations II

#LeetCode 47. 视频讲解:回溯算法求解全排列,如何去重?| LeetCode:47.全排列 II_哔哩哔哩_bilibili

如果完成了之前的题目,那么这个题目较简单,排列的思想与上一个题目相似,去重与之前组合去重相似,记得数组需要排序。

回溯方法代码:

class Solution {List<List<Integer>> result = new ArrayList<>();LinkedList<Integer> path = new LinkedList<>();public List<List<Integer>> permuteUnique(int[] nums) {boolean[] used = new boolean[nums.length];Arrays.fill(used, false);Arrays.sort(nums);backtracking(nums, used);return result;}public void backtracking(int[] nums, boolean[] used) {if (path.size() == nums.length) {result.add(new LinkedList<>(path));return;}for (int i = 0; i < nums.length; i++) {if (i > 0 && nums[i] == nums[i-1] && !used[i-1]) {continue;}if (used[i]) {continue;}path.addLast(nums[i]);used[i] = true;backtracking(nums, used);used[i] = false;path.removeLast();}}
}
http://www.yayakq.cn/news/998596/

相关文章:

  • 网站开发时什么时间适合创建视图抖音账号权重查询
  • 开源商城网站网站建设与管理案例教程第三版答案
  • 网站建设毕业设计中期检查设计招聘信息
  • 做学校子网站网站建设与管理基础
  • 移动网站建设制作58同城济南网站建设
  • 进入网上商城seo入门讲解
  • 网站开发报价表的文档织梦网站转移
  • 用自己的电脑做视频网站coding.net wordpress
  • 做封面的网站在哪里企业名录搜索软件排名
  • 织梦57网站的友情链接怎么做有免费的网站服务器吗
  • 珠海做网站找哪家公司怎么注册阿里巴巴店铺
  • 默认网站停止关键词排名是由什么决定的
  • 做网站用方正字体可以额的公司装修开工大吉贺词
  • 关于企业网站建设的相关思考买网站空间
  • jsp做的网站答辩问题福州网站建设设计公司
  • 酒类网站建河南郑州旅游网站制作
  • 网站项目风险wordpress登出
  • 求个网站好人一生平安电商仓储代发招商合作
  • 网站建设资料app关键词推广
  • 阿里云自助建站教程wordpress调用导航代码
  • 广州注册公司流程及资料南阳网站优化费用
  • dedecms 资源类网站模板网页设计与制作教程素材
  • 如何申请开通网站wordpress 代码格式化
  • 网站建设分几类seo技术培训唐山
  • dedecms做企业网站网站消耗流量
  • 东莞网站制作外包刘洋网站建设 够完美
  • 做网站项目需求分析是什么wordpress自动电影釆集
  • 沧州做网站最好的公司wordpress文章首页
  • 网站建设 业务板块名称中国建筑是国企还是央企
  • 城市门户网站域名过期了怎么办怎么找回网站