代码随想录第25天|回溯part5 通用的去重法:set

2024-06-06 06:52

本文主要是介绍代码随想录第25天|回溯part5 通用的去重法:set,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

491.非递减子序列

中等题
在这里插入图片描述
这个题给出的实例很有陷阱性,之前的题是通过排序来对于相同树层的元素去重,而本题是求非递减子序列,如果排序了那就已经是自增子序列了,达不到题目的要求。
看图
在这里插入图片描述
可以看出,对于一个集合[4,7],如果之前选择了7,那么在后面的7就不必选择了,因为如果选择了前面的7之后,一定递归到了包含了选择后一个7产生的所有情况
比如[4,7,6,7,9]
选择前面的7则有[4,7,7,9] [4,7] [4,7,9] [4,7,7]
如果只是选择后面的 7则有情况[4,7] [4,7,9] 可以看出前面一定是包括了后面的情况的,所以我们同样需要对于同一树层选择的元素去重
同一父节点下的同层上使用过的元素就不能再使用了

需要注意的点,unordered_set uset; 是记录本层元素是否重复使用,新的一层uset都会重新定义(清空),所以要知道uset只负责本层!所以递归完之后不需要清除,因为代表已使用过

class Solution {
public:vector<vector<int>> res;vector<int> path;void backTracking(vector<int>& nums, int step) {if (path.size() >= 2) {res.push_back(path);}if (step >= nums.size()) {return;}unordered_set<int> uset;for (int i = step; i < nums.size(); i++) {if (uset.find(nums[i]) != uset.end())continue;if (path.size() > 0 && path[path.size() - 1] > nums[i])continue;uset.insert(nums[i]);path.push_back(nums[i]);backTracking(nums, i + 1);path.pop_back();}}vector<vector<int>> findSubsequences(vector<int>& nums) {// sort(nums.begin(),nums.end());backTracking(nums, 0);return res;}
};

go代码

var (res  [][]intpath []int
)func backTracking(nums []int, step int) {if len(path) > 1 {p := make([]int, len(path))copy(p, path)res = append(res, p)}if step >= len(nums) {return}uset := make(map[int]bool)for i := step; i < len(nums); i++ {if uset[nums[i]] {continue}if len(path) > 0 && path[len(path)-1] > nums[i] {continue}uset[nums[i]] = truepath = append(path, nums[i])backTracking(nums, i+1)path = path[:len(path)-1]}
}func findSubsequences(nums []int) [][]int {res = [][]int{}path = []int{}backTracking(nums, 0)return res
}

46.全排列

在这里插入图片描述
模板题,不多说了,它不允许有重复元素出现
go代码

var (used []boolres  [][]intpath []int
)func backTracking(nums []int, used []bool) {if len(path) == len(nums) {temp := make([]int, len(path))copy(temp, path)res = append(res, temp)return}for i := 0; i < len(nums); i++ {if used[i] {continue}used[i] = truepath = append(path, nums[i])backTracking(nums, used)used[i] = falsepath = path[:len(path)-1]}
}
func permute(nums []int) [][]int {used = make([]bool, len(nums))res = [][]int{}path = []int{}backTracking(nums, used)return res
}

47.全排列2

在这里插入图片描述
这道题和之前的区别就是,它允许有重复元素出现,这就会导致在同一树层中可能选取值相同的元素,所以需要去重,这道题可以排序用used数组,也可以定义uset集合,这里我定义了集合

class Solution {
public:vector<vector<int>> res;vector<int> path;void backTracking(vector<int>& nums, vector<bool>& used) {if (path.size() == nums.size()) {res.push_back(path);return;}unordered_set<int> uset;for (int i = 0; i < nums.size(); i++) {if (uset.find(nums[i]) != uset.end()) {continue;}if (used[i])continue;used[i] = true;uset.insert(nums[i]);path.push_back(nums[i]);backTracking(nums, used);used[i] = false;path.pop_back();}}vector<vector<int>> permuteUnique(vector<int>& nums) {vector<bool> used(nums.size(), false);backTracking(nums, used);return res;}
};

这篇关于代码随想录第25天|回溯part5 通用的去重法:set的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来

poj 1258 Agri-Net(最小生成树模板代码)

感觉用这题来当模板更适合。 题意就是给你邻接矩阵求最小生成树啦。~ prim代码:效率很高。172k...0ms。 #include<stdio.h>#include<algorithm>using namespace std;const int MaxN = 101;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int n

poj 3050 dfs + set的妙用

题意: 给一个5x5的矩阵,求由多少个由连续6个元素组成的不一样的字符的个数。 解析: dfs + set去重搞定。 代码: #include <iostream>#include <cstdio>#include <set>#include <cstdlib>#include <algorithm>#include <cstring>#include <cm

计算机毕业设计 大学志愿填报系统 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点赞 👍 收藏 ⭐评论 📝 🍅 文末获取源码联系 👇🏻 精彩专栏推荐订阅 👇🏻 不然下次找不到哟~Java毕业设计项目~热门选题推荐《1000套》 目录 1.技术选型 2.开发工具 3.功能

代码随想录冲冲冲 Day39 动态规划Part7

198. 打家劫舍 dp数组的意义是在第i位的时候偷的最大钱数是多少 如果nums的size为0 总价值当然就是0 如果nums的size为1 总价值是nums[0] 遍历顺序就是从小到大遍历 之后是递推公式 对于dp[i]的最大价值来说有两种可能 1.偷第i个 那么最大价值就是dp[i-2]+nums[i] 2.不偷第i个 那么价值就是dp[i-1] 之后取这两个的最大值就是d

pip-tools:打造可重复、可控的 Python 开发环境,解决依赖关系,让代码更稳定

在 Python 开发中,管理依赖关系是一项繁琐且容易出错的任务。手动更新依赖版本、处理冲突、确保一致性等等,都可能让开发者感到头疼。而 pip-tools 为开发者提供了一套稳定可靠的解决方案。 什么是 pip-tools? pip-tools 是一组命令行工具,旨在简化 Python 依赖关系的管理,确保项目环境的稳定性和可重复性。它主要包含两个核心工具:pip-compile 和 pip

D4代码AC集

贪心问题解决的步骤: (局部贪心能导致全局贪心)    1.确定贪心策略    2.验证贪心策略是否正确 排队接水 #include<bits/stdc++.h>using namespace std;int main(){int w,n,a[32000];cin>>w>>n;for(int i=1;i<=n;i++){cin>>a[i];}sort(a+1,a+n+1);int i=1

Collection List Set Map的区别和联系

Collection List Set Map的区别和联系 这些都代表了Java中的集合,这里主要从其元素是否有序,是否可重复来进行区别记忆,以便恰当地使用,当然还存在同步方面的差异,见上一篇相关文章。 有序否 允许元素重复否 Collection 否 是 List 是 是 Set AbstractSet 否

论文翻译:ICLR-2024 PROVING TEST SET CONTAMINATION IN BLACK BOX LANGUAGE MODELS

PROVING TEST SET CONTAMINATION IN BLACK BOX LANGUAGE MODELS https://openreview.net/forum?id=KS8mIvetg2 验证测试集污染在黑盒语言模型中 文章目录 验证测试集污染在黑盒语言模型中摘要1 引言 摘要 大型语言模型是在大量互联网数据上训练的,这引发了人们的担忧和猜测,即它们可能已

html css jquery选项卡 代码练习小项目

在学习 html 和 css jquery 结合使用的时候 做好是能尝试做一些简单的小功能,来提高自己的 逻辑能力,熟悉代码的编写语法 下面分享一段代码 使用html css jquery选项卡 代码练习 <div class="box"><dl class="tab"><dd class="active">手机</dd><dd>家电</dd><dd>服装</dd><dd>数码</dd><dd