力扣labuladong一刷day67天回溯大集合

2024-01-25 12:52

本文主要是介绍力扣labuladong一刷day67天回溯大集合,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

力扣labuladong一刷day67天回溯大集合

文章目录

      • 力扣labuladong一刷day67天回溯大集合
      • 一、93. 复原 IP 地址
      • 二、78. 子集
      • 三、90. 子集 II

一、93. 复原 IP 地址

题目链接:https://leetcode.cn/problems/restore-ip-addresses/description/
思路:分割字符串和排序数字其实是差不多的,分割出来的IP地址是讲究顺序的,所以也不用考虑去重,正常回溯模板即可,另外就是剪枝早停,可以节省时间,截了3个数了,最后一个4位数超3位了直接停止,能节省不少时间。类始于之前的题目分割回文串,要求返回所有的分割方案,也是不需要去重的,分割aaa,为a,aa和aa,a这是两种分割方案。

class Solution {List<String> list;List<String> arrayList;public List<String> restoreIpAddresses(String s) {list = new ArrayList<>();arrayList = new ArrayList<>();backTracking(s, 0);return arrayList;}void backTracking(String s, int index) {if (list.size() == 4) {if (index == s.length()) {String join = String.join(".", list);arrayList.add(join);}return;}for (int i = index; i < s.length(); i++) {if (list.size() == 3 && i-index > 2) return;String temp = isTrue(s, index, i + 1);if (temp == null) continue;list.add(temp);backTracking(s, i+1);list.remove(list.size()-1);}}String isTrue(String s, int i, int j) {if (i == j-1) {return String.valueOf(s.charAt(i));}if (s.charAt(i) == '0' || j-i > 3) return null;String temp = s.substring(i, j);if (Integer.valueOf(temp) > 255) return null;return temp;}
}

二、78. 子集

题目链接:https://leetcode.cn/problems/subsets/description/
思路:子集问题求所有子集,元素不重复,要求子集也不重复,只需要index每次加一即可。另外求的是全部子集,故需要在所有节点搜集元素,而不是叶子节点。注意这一点即可。组合问题和分割问题都是收集树的叶子节点,而子集问题是找树的所有节点。

class Solution {List<Integer> list;List<List<Integer>> arrayLists;public List<List<Integer>> subsets(int[] nums) {list = new ArrayList<>();arrayLists = new ArrayList<>();backTracking(nums, 0);return arrayLists;}void backTracking(int[] nums, int index) {arrayLists.add(new ArrayList<>(list));for (int i = index; i < nums.length; i++) {list.add(nums[i]);backTracking(nums, i+1);list.remove(list.size()-1);}}
}

三、90. 子集 II

题目链接:https://leetcode.cn/problems/subsets-ii/description/
思路:本题的子集是如nums = [1,2,2]这种,包含重复元素,单个元素不可重复选,要求子集无重,不可重复选只需要index每次加一即可,要求子集无重,就需要横向去重,在同一个树层,相同的元素左边的孩子用了,右边的就不能用了,有一个技巧,需要排序,让相同的数都挨着,通过if (i > index && nums[i] == nums[i-1]) continue;进行跳过。

class Solution {List<List<Integer>> arrayLists;List<Integer> list;public List<List<Integer>> subsetsWithDup(int[] nums) {arrayLists = new ArrayList<>();list = new ArrayList<>();Arrays.sort(nums);backTracking(nums, 0);return arrayLists;}void backTracking(int[] nums, int index) {arrayLists.add(new ArrayList<>(list));for (int i = index; i < nums.length; i++) {if (i > index && nums[i] == nums[i-1]) continue;list.add(nums[i]);backTracking(nums, i+1);list.remove(list.size()-1);}}
}

这篇关于力扣labuladong一刷day67天回溯大集合的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/643326

相关文章

Java中的数组与集合基本用法详解

《Java中的数组与集合基本用法详解》本文介绍了Java数组和集合框架的基础知识,数组部分涵盖了一维、二维及多维数组的声明、初始化、访问与遍历方法,以及Arrays类的常用操作,对Java数组与集合相... 目录一、Java数组基础1.1 数组结构概述1.2 一维数组1.2.1 声明与初始化1.2.2 访问

关于集合与数组转换实现方法

《关于集合与数组转换实现方法》:本文主要介绍关于集合与数组转换实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、Arrays.asList()1.1、方法作用1.2、内部实现1.3、修改元素的影响1.4、注意事项2、list.toArray()2.1、方

C#之List集合去重复对象的实现方法

《C#之List集合去重复对象的实现方法》:本文主要介绍C#之List集合去重复对象的实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C# List集合去重复对象方法1、测试数据2、测试数据3、知识点补充总结C# List集合去重复对象方法1、测试数据

Python容器类型之列表/字典/元组/集合方式

《Python容器类型之列表/字典/元组/集合方式》:本文主要介绍Python容器类型之列表/字典/元组/集合方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 列表(List) - 有序可变序列1.1 基本特性1.2 核心操作1.3 应用场景2. 字典(D

Java集合中的List超详细讲解

《Java集合中的List超详细讲解》本文详细介绍了Java集合框架中的List接口,包括其在集合中的位置、继承体系、常用操作和代码示例,以及不同实现类(如ArrayList、LinkedList和V... 目录一,List的继承体系二,List的常用操作及代码示例1,创建List实例2,增加元素3,访问元

C#比较两个List集合内容是否相同的几种方法

《C#比较两个List集合内容是否相同的几种方法》本文详细介绍了在C#中比较两个List集合内容是否相同的方法,包括非自定义类和自定义类的元素比较,对于非自定义类,可以使用SequenceEqual、... 目录 一、非自定义类的元素比较1. 使用 SequenceEqual 方法(顺序和内容都相等)2.

基于Redis有序集合实现滑动窗口限流的步骤

《基于Redis有序集合实现滑动窗口限流的步骤》滑动窗口算法是一种基于时间窗口的限流算法,通过动态地滑动窗口,可以动态调整限流的速率,Redis有序集合可以用来实现滑动窗口限流,本文介绍基于Redis... 滑动窗口算法是一种基于时间窗口的限流算法,它将时间划分为若干个固定大小的窗口,每个窗口内记录了该时间

uva 11178 计算集合模板题

题意: 求三角形行三个角三等分点射线交出的内三角形坐标。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#include <stack>#include <vector>#include <

两数之和--力扣1

两数之和 题目思路C++代码 题目 思路 根据题目要求,元素不能重复且不需要排序,我们这里使用哈希表unordered_map。注意题目说了只对应一种答案。 所以我们在循环中,使用目标值减去当前循环的nums[i],得到差值,如果我们在map中能够找到这个差值,就说明存在两个整数的和为目标值。 如果没有找到,就将当前循环的nums[i]以及下标i放入map中,以便后续查

Java基础回顾系列-第六天-Java集合

Java基础回顾系列-第六天-Java集合 集合概述数组的弊端集合框架的优点Java集合关系图集合框架体系图java.util.Collection接口 List集合java.util.List接口java.util.ArrayListjava.util.LinkedListjava.util.Vector Set集合java.util.Set接口java.util.HashSetjava