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

怎么给网站制作二维码哪个平台可以免费发广告

怎么给网站制作二维码,哪个平台可以免费发广告,wordpress自定义右键,淮南百姓网回溯算法part05 491.递增子序列解题思路与 90.子集II 不同的点回溯三部曲 46.全排列解题思路遇到的难点思考 47.全排列 II解题思路注意点拓展需要加深理解的点(需复习 小总结 491.递增子序列 本题和大家刚做过的90.子集II非常像,但又很不一样&#xff0c…

回溯算法part05

  • 491.递增子序列
    • 解题思路
      • 与` 90.子集II `不同的点
      • 回溯三部曲
  • 46.全排列
    • 解题思路
      • 遇到的难点
      • 思考
  • 47.全排列 II
    • 解题思路
      • 注意点
      • 拓展
      • 需要加深理解的点(需复习
  • 小总结

491.递增子序列

本题和大家刚做过的90.子集II非常像,但又很不一样,很容易掉坑里。
题目链接: 491.递增子序列
文章讲解: 491.递增子序列
视频讲解: 491.递增子序列

解题思路

90.子集II中我们是通过排序,再加一个标记数组来达到去重的目的。

而本题求自增子序列,是不能对原数组进行排序的,排完序的数组都是自增子序列了。

90.子集II不同的点

  1. 不能排序
  2. 不能用之前的used[]数组,而要用set,且set不需要跟着回溯,只负责本层里面取了哪些元素
  3. 需要判断每个path中元素个数是否大于等于2
  4. 需要判断每个path是否是递增的

回溯三部曲

  1. 递归函数参数:
  • 全局变量result和path
  • startIndex
  1. 终止条件:
    要遍历整个树,可以没有
  2. 单层遍历逻辑
  • 去重逻辑
  • 局部变量HashSet uset; 记录本层元素是否重复使用,新的一层uset都会重新定义(清空),所以要知道uset只负责本层!
    在这里插入图片描述
// uset用数组实现 效率高一些
class Solution {List<List<Integer>> result = new ArrayList<>();List<Integer> path = new LinkedList<>();public List<List<Integer>> findSubsequences(int[] nums) {backTracking(nums, 0);return result;}public void backTracking(int[] nums, int startIndex){if(path.size() >= 2){result.add(new ArrayList<>(path));}if(startIndex >= nums.length){ // 这个终止条件可以没有,因为我们要遍历整个树return;}int[] uset = new int[201];for(int i = startIndex; i <nums.length; i++){if(!path.isEmpty() && path.get(path.size() - 1) > nums[i] || uset[nums[i] + 100] == 1) continue; //注意是continue而不是breakuset[nums[i] + 100] = 1;path.add(nums[i]);backTracking(nums, i + 1);path.remove(path.size() - 1);}}    
}
// // uset用set实现
class Solution {List<List<Integer>> result = new ArrayList<>();List<Integer> path = new LinkedList<>();public List<List<Integer>> findSubsequences(int[] nums) {backTracking(nums, 0);return result;}public void backTracking(int[] nums, int startIndex){if(path.size() >= 2){result.add(new ArrayList<>(path));}if(startIndex >= nums.length){ // 这个终止条件可以没有,因为我们要遍历整个树return;}HashSet<Integer> uset = new HashSet<>();for(int i = startIndex; i <nums.length; i++){if(!path.isEmpty() && path.get(path.size() - 1) > nums[i] || uset.contains(nums[i])) continue; //注意是continue而不是breakuset.add(nums[i]);path.add(nums[i]);backTracking(nums, i + 1);path.removeLast();}}
}

46.全排列

本题重点感受一下,排列问题 与 组合问题,组合总和,子集问题的区别。 为什么排列问题不用 startIndex
题目链接: 46.全排列
文章讲解: 46.全排列
视频讲解: 46.全排列

解题思路

不需要i = startIndex控制for循环开始位置,每次从i = 0开始
需要判断当前元素是否已经取过

遇到的难点

如何不重复取自身元素:used数组,其实就是记录此时path里都有哪些元素使用了,一个排列里一个元素只能使用一次

思考

这道题的used数组和之前题目中的used数组作用的不同

  • 这道题的used数组:记录此时path里都有哪些元素使用了
  • 之前题目中的used数组:树层上对组合去重,一般要先将数组排序
    在这里插入图片描述
// 解法1:通过判断path中是否存在数字,排除已经选择的数字
// 感觉这种比解法2好理解
class Solution {List<List<Integer>> result = new ArrayList<>();LinkedList<Integer> path = new LinkedList<>();public List<List<Integer>> permute(int[] nums) {if (nums.length == 0) return result;backtrack(nums, path);return result;}public void backtrack(int[] nums, LinkedList<Integer> path) {if (path.size() == nums.length) {result.add(new ArrayList<>(path));}for (int i =0; i < nums.length; i++) {// 如果path中已有,则跳过if (path.contains(nums[i])) {continue;} path.add(nums[i]);backtrack(nums, path);path.removeLast();}}
}
// 法2:通过used判断是否path中已取过当前数字
class Solution {List<List<Integer>> result = new ArrayList<>();List<Integer> path = new LinkedList<>();boolean[] used;public List<List<Integer>> permute(int[] nums) {used = new boolean[nums.length];backTracking(nums);return result;}public void backTracking(int[] nums){if(path.size() == nums.length){result.add(new ArrayList<>(path));}for(int i = 0; i < nums.length; i++){if(used[i]){continue;}used[i] = true;path.add(nums[i]);backTracking(nums);used[i] = false;path.removeLast();}}
}

47.全排列 II

本题 就是我们讲过的40.组合总和II去重逻辑 和46.全排列的结合,可以先自己做一下,然后重点看一下 文章中 我讲的拓展内容。 used[i - 1] == true 也行,used[i - 1] == false 也行
题目链接: 47.全排列 II
文章讲解: 47.全排列 II
视频讲解: 47.全排列 II

解题思路

40.组合总和II去重逻辑 和46.全排列的结合

注意点

nums数组排序

Arrays.sort(nums);

树层去重

if(i > 0 && nums[i - 1] == nums[i] && used[i - 1] == false) continue;  // 树层去重

取过的元素不再重复取

if(used[i] == true) continue;    // 取过的数标记为1

拓展

去重代码中,如果改成 used[i - 1] == true, 也是正确的!
这是为什么呢,就是上面我刚说的,如果要对树层中前一位去重,就用used[i - 1] == false,如果要对树枝前一位去重用used[i - 1] == true。
对于排列问题,树层上去重和树枝上去重,都是可以的,但是树层上去重效率更高!
树枝去重图例
在这里插入图片描述

需要加深理解的点(需复习

  • 树层去重和树枝去重
  • used数组在不同题中的作用
  • 为什么这道题的used数组需要作为参数参与递归结合40.组合总和II90.子集II进行思考
  • 491.递增子序列中的uset
    在这里插入图片描述

小总结

491.递增子序列 不能用之前的used[]数组,而要用set,且set不需要跟着回溯,只负责本层里面取了哪些元素 used数组不需要回溯,不需要放在递归参数里面
46.全排列 used数组,其实就是记录此时path里都有哪些元素使用了,一个排列里一个元素只能使用一次 used数组要回溯,要放在递归参数里面
47.全排列 II used数组:去重+取过的元素不再重复取 used数组要回溯,要放在递归参数里面

class Solution {List<List<Integer>> result = new ArrayList<>();List<Integer> path = new LinkedList<>();boolean[] used;public List<List<Integer>> permuteUnique(int[] nums) {used = new boolean[nums.length];Arrays.sort(nums);backTracking(nums, used);return result;}public void backTracking(int[] nums, boolean[] used){if(path.size() == nums.length){result.add(new ArrayList<>(path));return;}for (int i =0; i < nums.length; i++) {// 树层去重if(i > 0 && nums[i - 1] == nums[i] && used[i - 1] == false) continue;  // 树层去重if(used[i] == true) continue;    // 取过的数标记为1used[i] = true;path.add(nums[i]);backTracking(nums, used);used[i] = false;path.removeLast();}}
}

文章转载自:
http://frikadel.gthc.cn
http://smds.gthc.cn
http://finalist.gthc.cn
http://mollusk.gthc.cn
http://usquebaugh.gthc.cn
http://welshy.gthc.cn
http://insertion.gthc.cn
http://shoeshop.gthc.cn
http://weet.gthc.cn
http://shortcoming.gthc.cn
http://noncommunicable.gthc.cn
http://mediatory.gthc.cn
http://philadelphia.gthc.cn
http://transcription.gthc.cn
http://norite.gthc.cn
http://sizing.gthc.cn
http://wham.gthc.cn
http://videophone.gthc.cn
http://scrofulous.gthc.cn
http://lecturee.gthc.cn
http://sunglow.gthc.cn
http://adipoma.gthc.cn
http://marline.gthc.cn
http://merciful.gthc.cn
http://proceeding.gthc.cn
http://amusedly.gthc.cn
http://pent.gthc.cn
http://packplane.gthc.cn
http://instilment.gthc.cn
http://fluff.gthc.cn
http://biophile.gthc.cn
http://mulligatawny.gthc.cn
http://tass.gthc.cn
http://chereme.gthc.cn
http://hhfa.gthc.cn
http://interrogation.gthc.cn
http://ungrammatical.gthc.cn
http://permissivism.gthc.cn
http://marabou.gthc.cn
http://silliness.gthc.cn
http://verbalism.gthc.cn
http://ravishing.gthc.cn
http://fibro.gthc.cn
http://toccata.gthc.cn
http://scrannel.gthc.cn
http://eyeshot.gthc.cn
http://rhododendron.gthc.cn
http://dividend.gthc.cn
http://apprehensively.gthc.cn
http://impo.gthc.cn
http://kapellmeister.gthc.cn
http://obliviscence.gthc.cn
http://unaccomplished.gthc.cn
http://bosomy.gthc.cn
http://uranide.gthc.cn
http://downslope.gthc.cn
http://phonics.gthc.cn
http://suppositional.gthc.cn
http://homozygosity.gthc.cn
http://duluth.gthc.cn
http://macroetch.gthc.cn
http://disgust.gthc.cn
http://radiomimetic.gthc.cn
http://carcinogen.gthc.cn
http://cosmetic.gthc.cn
http://ulminic.gthc.cn
http://sensitiser.gthc.cn
http://mensurability.gthc.cn
http://elding.gthc.cn
http://epiphloedal.gthc.cn
http://phoenicaceous.gthc.cn
http://hydrolase.gthc.cn
http://topocentric.gthc.cn
http://pentatonism.gthc.cn
http://softland.gthc.cn
http://euthanatize.gthc.cn
http://chemurgy.gthc.cn
http://mystagogic.gthc.cn
http://drawspring.gthc.cn
http://unnational.gthc.cn
http://adverbial.gthc.cn
http://academically.gthc.cn
http://regard.gthc.cn
http://icc.gthc.cn
http://robotomorphic.gthc.cn
http://undeceive.gthc.cn
http://attorn.gthc.cn
http://inducer.gthc.cn
http://garamond.gthc.cn
http://fornical.gthc.cn
http://kvetch.gthc.cn
http://iberis.gthc.cn
http://paisan.gthc.cn
http://vogue.gthc.cn
http://broederbond.gthc.cn
http://computerlike.gthc.cn
http://cajeput.gthc.cn
http://clavecinist.gthc.cn
http://prepense.gthc.cn
http://hadron.gthc.cn
http://www.15wanjia.com/news/103574.html

相关文章:

  • 域名申请好了 怎么做网站优书网首页
  • 建成学校网站中国最新消息新闻
  • 程序员自己做项目的网站个人怎么做互联网推广平台
  • 专做婴儿的网站互联网+营销策略怎么写
  • 怎么利用花生壳做自己的网站seo人人网
  • 静态页面网站怎么做百度首页官网
  • 给孩子做衣服的网站百度营消 营销推广
  • 杭州网站开发公司外包公司是什么意思
  • 成都有哪些软件开发公司seo技术交流
  • ps做全屏网站画布要多大百度seo新规则
  • 浙江省杭州市建设厅网站营销网站建设制作
  • 郑州网站制作公司360竞价推广怎么做
  • 傻瓜式网站开发软件友情链接查询结果
  • 网站建设制作方案个人网站制作
  • 如何做律所网站排名网站
  • tiktok官网版下载百度seo怎么做网站内容优化
  • 深圳响应式网站建设网站优化 福州
  • 企石镇网站仿做百度推广怎么运营
  • 网站赚流量关键词优化一般收费价格
  • 连云港网站优化方案宣传推广策略
  • 关于asp.net的网站模板seo顾问公司
  • 汕头装修接单网站网络营销比较成功的企业
  • app制作免费官网在运营中seo是什么意思
  • 雷山网站建设百度人工客服在线咨询
  • 网站app怎么做的智慧软文发稿平台
  • 网站内外链怎么做效果好搜索指数的数据来源
  • wordpress二次开发主题优化大师官方免费下载
  • 电影网站建设百度识图扫一扫入口
  • 做食品网站需要什么资质百度seo免费推广教程
  • 拼多多网站搜索引擎营销的模式有哪些