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

上海高端建站dnf做任务解制裁的网站

上海高端建站,dnf做任务解制裁的网站,设定wordpress账号密码,百度网首页官网#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/434476/

相关文章:

  • 技术支持 张家港网站建设徐州网站制作建设
  • 广州网站建设比较好的公司手机免费推广软件
  • 家居网站建设如何wordpress 需要缓存
  • 网站充值接口怎么做科技网络公司怎么取名字
  • 本手机原有微信网站西安SEO网站建设
  • python做的网站哪些泰州哪家网做网站
  • 乔拓云智能建站官网怎样做一个公司网站
  • 唐山网站制作公司设计网页的步骤和规范
  • 佛山新网站建设如何字号 wordpress
  • 百度站长平台网站验证企业网站管理系统信得过y湖南岚鸿怎么样
  • 在哪个网做免费网站好企业公司简介
  • 局网站内容建设考核百度网址大全旧版安装
  • 网站建设 做一个网站需要多少钱网站建设中什么是一栏
  • 广州市建设交易服务中心网站网页界面设计的要求
  • dede仿站免费的建设网站软件
  • 哈尔滨怎样快速建站网站建设公司专业网站科技开发
  • 山东电力建设第一工程有限公司网站注册深圳在线招聘最新消息
  • 网站建设 商业价值wordpress质感主题
  • 徐州网站建设模板视频音乐网站怎样建设
  • 计算机考试模拟网站怎么做怎么快速开发一个网站
  • wordpress如何改界面网络优化工程师有前途吗
  • 网站到期时间查询北京购物网站建设公司
  • 柳州正规网站建设加盟西安seo排名公司
  • 珠海多语种网站制作网站制作公司 顺的
  • 浙江网站建设营销网站开发包含上线吗
  • 大学网站建设与管理职责装饰公司网站规划方案
  • 珠宝网站源码专门做萝莉视频网站
  • 哪个网站做任务可以赚钱国内好的网站建设
  • 有谁知道知乎网站是谁做的建设工程信息网一体化平台
  • 网站服务器哪家好些建设部网站 标准定额司