leetcode_78子集

news/2025/2/8 18:12:46/

1. 题意

给定一个不含有重复数字的数列,求所有的子集。

2. 题解

子集型回溯,可以直接用dfs进行搜索;也可以用二进制来进行枚举。

2.1 选或不选
class Solution {
public:void dfs(vector<vector<int>> &ans,vector<int> &tmp,vector<int> &nums, int depth) {if (depth == nums.size()) {ans.emplace_back(tmp );return;}dfs(ans, tmp, nums, depth + 1);tmp.push_back(nums[depth]);dfs(ans, tmp, nums, depth + 1);tmp.pop_back();}vector<vector<int>> subsets(vector<int>& nums) {vector<vector<int>> ans;vector<int> tmp;dfs( ans, tmp, nums, 0);return ans;}
};
2.2 选哪个
class Solution {
public:void dfs(vector<vector<int>> &ans,vector<int> &tmp,vector<int> &nums, int depth) {ans.emplace_back(tmp);for (int i = depth;i < nums.size(); i++) {tmp.push_back(nums[i]);dfs(ans, tmp, nums, i + 1);tmp.pop_back();}}vector<vector<int>> subsets(vector<int>& nums) {vector<vector<int>> ans;vector<int> tmp;dfs( ans, tmp, nums, 0);return ans;}
};
2.3 二进制枚举
class Solution {
public:vector<vector<int>> subsets(vector<int>& nums) {vector<vector<int>> ans;int sz = nums.size();for (int i = 0;i < (1 << sz); i++) {vector<int> tmp;for (int j = 0;j < sz;j++) {if (i & (1 << j))tmp.push_back(nums[j]);}ans.emplace_back( tmp );}return ans;}
};

参考

0x3f题解


http://www.ppmy.cn/news/1570377.html

相关文章

Swipe横滑与SwipeItem自定义横滑相互影响

背景 vue项目&#xff0c;H5页面&#xff0c;使用vant的组件库轮播组件<Swipe>&#xff0c;UI交互要求&#xff0c;在每个SwipeItem中有内容&#xff0c;可自横滑&#xff0c;查看列表内容 核心代码 <template><Swipeclass"my_swipe":autoplay&quo…

tcp/ip网络协议,tcp/ip网络协议栈

TCP/IP网络协议和TCP/IP网络协议栈是互联网通信的基石&#xff0c;它们定义了电子设备如何连入因特网以及数据如何在它们之间传输的标准。以下是对TCP/IP网络协议和TCP/IP网络协议栈的详细解释&#xff1a; 一、TCP/IP网络协议 TCP/IP&#xff08;Transmission Control Proto…

科技赋能数字内容体验的核心技术探索

内容概要 在数字化时代&#xff0c;科技的迅猛发展为我们的生活和工作带来了深刻的变革。数字内容体验已经成为人们获取信息和娱乐的重要途径&#xff0c;而这背后的技术支持则扮演着至关重要的角色。尤其是在人工智能、虚拟现实和区块链等新兴技术的推动下&#xff0c;数字内…

硬件电路基础

目录 1. 电学基础 1.1 原子 1.2 电压 1.3 电流 1.电流方向&#xff1a; 正极->负极,正电荷定向移动方向为电流方向&#xff0c;与电子定向移动方向相反。 2.电荷&#xff08;这里表示负电荷&#xff09;运动方向&#xff1a; 与电流方向相反 1.4 测电压的时候 2. 地线…

【算法】动态规划专题⑥ —— 完全背包问题 python

目录 前置知识进入正题模板 前置知识 【算法】动态规划专题⑤ —— 0-1背包问题 滚动数组优化 完全背包问题是动态规划中的一种经典问题&#xff0c;它与0-1背包问题相似&#xff0c;但有一个关键的区别&#xff1a;在完全背包问题中&#xff0c;每种物品都有无限的数量可用。…

VeryReport和FineReport两款报表软件深度分析对比

在当今数据驱动的商业环境中&#xff0c;报表软件已经成为企业管理和数据分析的重要工具。无论是中小型企业还是大型企业&#xff0c;都需要依赖高效的报表工具来快速生成、分析和展示数据。市面上有许多报表工具&#xff0c;其中VeryReport和FineReport是两款备受关注的国产报…

Java-序列化

定义以及相关概念 由于在系统底层&#xff0c;数据的传输形式是简单的字节序列形式传递&#xff0c;即在底层&#xff0c;系统不认识对象&#xff0c;只认识字节序列&#xff0c;而为了达到进程通讯的目的&#xff0c;需要先将数据序列化&#xff0c;而序列化就是将对象转化字节…

【MySQL系列】记插入产生的死锁问题

???欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学习,不断总结,共同进步,活到老学到老…