算法D29 | 回溯算法5|491.递增子序列 46.全排列 47.全排列 II

491.递增子序列 

本题和大家刚做过的 90.子集II 非常像,但又很不一样,很容易掉坑里。 

代码随想录

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

一个是去重,一个是判断是否递增;去重发生在横向,递增发生在纵向。

横向去重需要额外构建一个集合。

Python:

class Solution:def __init__(self):self.result = []self.path = []def backtracking(self, nums, start_index):if len(self.path)>=2:self.result.append(self.path[:])used_set = set()for i in range(start_index, len(nums)):if len(self.path)>=1 and nums[i]<self.path[-1]: # 纵向去重continueif nums[i] in used_set: # 横向去重continue                used_set.add(nums[i])self.path.append(nums[i])self.backtracking(nums, i+1)self.path.pop()returndef findSubsequences(self, nums: List[int]) -> List[List[int]]:self.backtracking(nums, 0)return self.result

C++:

class Solution {
public:vector<vector<int>> result;vector<int> path;void backtracking(vector<int>& nums, int startIndex) {if (path.size()>=2) result.push_back(path);unordered_set<int> uset;for (int i=startIndex; i<nums.size(); i++) {if (uset.find(nums[i])!=uset.end()) continue;if (!path.empty() && nums[i]<path.back()) continue;uset.insert(nums[i]);path.push_back(nums[i]);backtracking(nums, i+1);path.pop_back();}return;}vector<vector<int>> findSubsequences(vector<int>& nums) {backtracking(nums, 0);return result;    }
};

46.全排列 

本题重点感受一下,排列问题 与 组合问题,组合总和,子集问题的区别。 为什么排列问题不用 startIndex 

代码随想录

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

Python:

class Solution:def __init__(self):self.result = []self.path = []def backtracking(self, nums, k):if len(self.path)==k:self.result.append(self.path[:])for i in range(len(nums)):self.path.append(nums[i])new_nums = nums[:i] + nums[i+1:]self.backtracking(new_nums, k)self.path.pop()returndef permute(self, nums: List[int]) -> List[List[int]]:k = len(nums)self.backtracking(nums, k)return self.result

C++:

用指针实现标记是否使用过,更为节省内存和时间。

class Solution {
public:vector<vector<int>> result;vector<int> path;void backtracking(vector<int>& nums, vector<bool>& used) {if (path.size()==nums.size()) {result.push_back(path);return;}for (int i=0; i<nums.size(); i++) {if (used[i] == true) continue;used[i] = true;path.push_back(nums[i]);backtracking(nums, used);path.pop_back();used[i] = false;}return;}vector<vector<int>> permute(vector<int>& nums) {vector<bool> used(nums.size(), false);backtracking(nums, used);return result;    }
};

47.全排列 II 

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

代码随想录

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

Python:

class Solution:def __init__(self):self.result = []self.path = []def backtracking(self, nums, used):if len(self.path) == len(nums):self.result.append(self.path[:])returnuset = set()for i in range(len(nums)):if used[i]: continue        # 纵向去重if nums[i] in uset: continue # 横向去重uset.add(nums[i])used[i] = Trueself.path.append(nums[i])self.backtracking(nums, used)self.path.pop()used[i] = Falsereturndef permuteUnique(self, nums: List[int]) -> List[List[int]]:nums.sort()used = [False] * len(nums)self.backtracking(nums, used)return self.result

C++:

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/710322.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

在WPF MVVM 框架下实现DataGrid内容的增删查改

在WPF应用程序开发中&#xff0c;使用DataGrid控件来展示和编辑数据是一种常见的做法。Prism是一个模块化的WPF应用程序框架&#xff0c;它支持MVVM模式&#xff0c;使得实现数据操作和界面展示的分离变得更加容易。本文将指导您如何在使用Prism框架的WPF应用程序中实现DataGri…

【leetcode】链表分割

大家好&#xff0c;我是苏貝&#xff0c;本篇博客带大家刷题&#xff0c;如果你觉得我写的还不错的话&#xff0c;可以给我一个赞&#x1f44d;吗&#xff0c;感谢❤️ 目录 方法1. 不用哨兵位方法2. 用哨兵位 点击查看题目 思路: 将链表分为2个链表list1和list2&#xff0c;…

忙碌生活下的技术适应力:应对新应用学习带来的困扰与挑战

在当今信息时代&#xff0c;各类应用程序&#xff08;APP&#xff09;渗透到我们生活的方方面面&#xff0c;无论是工作效率提升&#xff0c;还是日常生活便利&#xff0c;都离不开它们的支持。然而&#xff0c;对于在快节奏工作中疲于奔命的现代人来说&#xff0c;当因为生活所…

GO语言学习笔记(与Java的比较学习)(七)

结构与方法 结构体定义 结构体定义的一般方式如下&#xff1a; type identifier struct {field1 type1field2 type2... } type T struct {a, b int} 也是合法的语法&#xff0c;它更适用于简单的结构体。 结构体里的字段都有 名字&#xff0c;像 field1、field2 等&#…

linux服务器连接数

一、要查看 Linux 服务器的最大连接数 我们需要关注两个值&#xff1a;文件描述符限制&#xff08;file descriptor limit&#xff09;和内核参数 "net.core.somaxconn"。 1. 查看文件描述符限制&#xff08;file descriptor limit&#xff09; 文件描述符限制决定了…

System Verilog学习笔记(十)——任务和函数

System Verilog学习笔记&#xff08;十&#xff09;——任务和函数 函数&#xff08;function&#xff09;和任务&#xff08;task&#xff09;可以提高代码的复用性和整洁度。他们的目的在于将大型的过程块切分为更小的片段&#xff0c;而便于阅读和代码维护。 区别 functi…

物联网边缘计算云边协同

文章目录 一、物联网云边协同1.IoT云边协同设计2.物联网平台设计3.物联网平台实现 二、部署环境1.节点配置2.版本信息 三、IoT云边协同部署1.部署Kubernetes集群2.部署KubeEdge3.部署ThingsBoard集群4.部署Node-RED边缘网关4.1.边缘网关功能4.2.部署EMQX4.2.部署Node-RED 5.配置…

(正规api接口代发布权限)短视频账号矩阵系统实现开发--技术全自动化saas营销链路生态

短视频账号矩阵系统实现开发--技术全自动化saas营销链路生态源头开发&#xff08;本篇禁止抄袭复刻&#xff09; 一、短视频矩阵系统开发者架构 云罗短视频矩阵系统saas化系统&#xff0c;开发层将在CAP原则基础上使用分布式架构,对此网站的整体架构采用了基于B/S三层架构模式…

React 模态框的设计(五)主体设计

弹窗的主体设计没什么特别&#xff0c;就是把细分化后的各个功能封装在一个个的小组件内&#xff0c;然后再整合。这样逻辑就分开了&#xff0c;不乱。 弹窗容器 这个容器是弹窗主体的根组件(不含遮罩)&#xff0c;要能根据主题的变化能做出相应的改变。还要记录渲染后的主体…

java016学习记录

Java Web 使用 Java 开发语言完成 Web 后端的项目开发 基于 Web 的应用&#xff1a;网站、APP、小程序 Java 不是做前端的&#xff0c;做后端 Tomcat、Servlet Tomcat 的作用让 Java Web 程序可以正常运行&#xff0c;被浏览器访问 浏览器默认不能访问电脑上的资源&#…

Django Web架构:全面掌握Django模型字段(下)

Django Web架构 全面掌握Django模型字段&#xff08;下&#xff09; - 文章信息 - Author: 李俊才 (jcLee95) Visit me at CSDN: https://jclee95.blog.csdn.netMy WebSite&#xff1a;http://thispage.tech/Email: 291148484163.com. Shenzhen ChinaAddress of this article…

C++之vector

1、vector概念 功能&#xff1a;vector的功能和数组非常相似&#xff0c;可以看成是一个升级版的数组。 vector和普通数组的区别&#xff1a; &#xff08;1&#xff09;数组是静态的&#xff0c;长度不可改变&#xff0c;而vector可以动态扩展&#xff0c;增加长度。…

协议和序列化反序列化

“协议”和序列化反序列化 “协议”的概念&#xff1a; “协议”本身是一种约定俗成的东西&#xff0c;由通讯双方必须共同遵从的一组约定&#xff0c;因此我们一定要将这种约定用计算机语言表达出来&#xff0c;此时双方计算机才能识别约定的相关内容 我们把这个规矩叫做“…

机器学习|决策树

左图的点是一种线性不可分的情况&#xff0c;无法拿一条直线去将进行分开。 每一个节点都代表一个决策&#xff0c;从而导致节点的分流。 最终的目标肯定是要达到分类。 但取得目标的过程是有所谓的好坏。 而这个好坏用熵/信息增益来衡量。 熵是一种用于反映系统混乱程度的物理…

思科网络设备监控

思科是 IT 行业的先驱之一&#xff0c;提供从交换机到刀片服务器的各种设备&#xff0c;以满足中小企业和企业的各种 IT 管理需求。管理充满思科的 IT 车间涉及许多管理挑战&#xff0c;例如监控可用性和性能、管理配置更改、存档防火墙日志、排除带宽问题等等&#xff0c;这需…

Makefile从入门到项目编译实战(学习笔记)

1.make和makefile介绍 1. make make 是一个应用程序&#xff0c;位于 /usr/bin/make 目录下&#xff0c;make 有如下的功能&#xff1a; &#xff08;1&#xff09;解析源程序之间的依赖关系 &#xff08;2&#xff09;根据依赖关系自动维护编译工作 &#xff08;3&#xff09…

Jmeter插件PerfMon Metrics Collector安装使用及报错解决

Jmeter作为一个轻量级的性能测试工具&#xff0c;开源、小巧、灵活的特性使其越来越受到测试人员喜爱。在实际的项目中&#xff0c;特别是跨地区项目&#xff0c;排除合作方指定要求使用Loadrunner作为性能测试工具外&#xff0c;Jmeter会是首选。 本篇文章&#xff0c;就着重…

Python 全栈系列226 GlobalBuffer

说明 为了简化开发程序&#xff0c;特别是需要依赖全局数据的程序&#xff0c;例如&#xff1a;分布式任务需要知道当前可处理的任务&#xff1b;定时程序需要依据某个约束性全局变量。一个附带的好处是会大量减少对数据库产生的请求。 GlobalBuffer的代价并不高&#xff1a;…

基于C++的http通信记录,使用httplib,Windows环境,vscode,mingw

使用了 httplib库&#xff0c;链接&#xff0c;使用该库只需要包含头文件即可&#xff0c;另外在Windows环境下&#xff0c;使用mingw构建项目&#xff0c;需要在编译时链接网络编程库&#xff0c;task.json如下&#xff1a; {"version": "2.0.0","t…

【MATLAB源码-第149期】基于MATLAB的2ASK,2FSK,2PSK,2DPSK等相干解调仿真,输出各节点波形。

操作环境&#xff1a; MATLAB 2022a 1、算法描述 2ASK&#xff08;二进制幅移键控&#xff09;、2FSK&#xff08;二进制频移键控&#xff09;、2PSK&#xff08;二进制相移键控&#xff09;和2DPSK&#xff08;二进制差分相移键控&#xff09;是数字调制技术中的基本调制方…