leetcode78.子集➕90.子集2
78子集
dfs
dfs1:
和全排列的区别就是对于当前考察的索引i,全排列如果不取i,之后还要取i,所以需要一个visited数组用来记录。对于子集问题如果不取i,之后也不必再取i。
单纯递归回溯
class Solution {
public:
vector<vector<int>> subsets(vector<int>& nums) {
vector<int> cur;
vector<vector<int>>res;
dfs(res,cur,nums,0);
return res;
}
void dfs(vector<vector<int>>&res,vector<int>&cur,vector<int>&nums,int nex){
res.push_back(cur);
for(int i=nex;i<nums.size();++i){
cur.push_back(nums[i]);
dfs(res,cur,nums,i+1);
cur.pop_back();
}
}
};
dfs2:类似树的递归遍历,一个dfs函数里有两个dfs递归子函数,一个是含当前数字的子递归,一个是不含当前数字的子递归。
class Solution {
public:
vector<vector<int>> subsets(vector<int>& nums) {
vector<int>cur;
vector<vector<int>>res;
dfs(res,cur,nums,0);
return res;
}
void dfs(vector<vector<int>>&res,vector<int>&cur,vector<int>&nums,int nex){
if(nex>=nums.size()){
res.push_back(cur);
return;
}
cur.push_back(nums[nex]);
dfs(res,cur,nums,nex+1);
cur.pop_back();
dfs(res,cur,nums,nex+1);
}
};
位运算
因为所以数字都不一一样,每个数字都有两种可能,一个取一个不取。假设一共n个元素,则一共有2的n次方个子集,其中每个子集都对应一个小于2的n次方的数。如n==4,1001对应首尾数字取,中间两个数字不取
class Solution {
public:
vector<vector<int>> subsets(vector<int>& nums) {
int n=nums.size();
vector<vector<int>>res;
for(int i=0;i<pow(2,n);++i){
int j=i,k=n-1;
res.push_back({});
while(j){
if(j&1){
res.back().push_back(nums[k]);
}
j>>=1;
--k;
}
}
return res;
}
};
循环
空生空+【1】,空加【1】生空+【1】加【2】加【1,2】。
即1生2,2生4,4生8。。。。
class Solution {
public:
vector<vector<int>> subsets(vector<int>& nums) {
vector<vector<int>>res={{}};
for(const int& num:nums){
int cur_size=res.size();
for(int i=0;i<cur_size;++i){
res.push_back(res[i]);
res.back().push_back(num);
}
}
return res;
}
};
90 子集2
循环
class Solution {
public:
vector<vector<int>> subsetsWithDup(vector<int>& nums) {
vector<vector<int>>res={{}};
unordered_map<int,int> mp;
for(int num:nums){
mp[num]+=1;
}
for(const auto& pai:mp){
int cur_size=res.size();
for(int i=0;i<cur_size;++i){
res.push_back(res[i]);
for(int j=0;j<pai.second;++j){
res.back().push_back(pai.first);
res.push_back(res.back());
}
res.pop_back();
}
}
return res;
}
};
dfs
class Solution {
public:
vector<vector<int>> subsetsWithDup(vector<int>& nums) {
sort(nums.begin(),nums.end());
vector<vector<int>> res;
vector<int>cur;
dfs(res,nums,cur,0);
return res;
}
void dfs(vector<vector<int>>&res,vector<int>&nums,vector<int>&cur,int nex){
res.push_back(cur);
for(int i=nex;i<nums.size();++i){
while(i-1>=nex and i<nums.size() and nums[i]==nums[i-1]){
++i;
}
if(i>=nums.size()){return;}
cur.push_back(nums[i]);
dfs(res,nums,cur,i+1);
cur.pop_back();
}
}
};
leetcode78.子集➕90.子集2的更多相关文章
- 90. 子集 II
90. 子集 II 题意 给定一个可能包含重复元素的整数数组 nums,返回该数组所有可能的子集(幂集). 说明:解集不能包含重复的子集. 示例: 输入: [1,2,2]输出:[ [2], [1], ...
- Leetcode之回溯法专题-90. 子集 II(Subsets II)
Leetcode之回溯法专题-90. 子集 II(Subsets II) 给定一个可能包含重复元素的整数数组 nums,返回该数组所有可能的子集(幂集). 说明:解集不能包含重复的子集. 示例: 输入 ...
- Java实现 LeetCode 90 子集 II(二)
90. 子集 II 给定一个可能包含重复元素的整数数组 nums,返回该数组所有可能的子集(幂集). 说明:解集不能包含重复的子集. 示例: 输入: [1,2,2] 输出: [ [2], [1], [ ...
- [leetcode] 90. 子集 II.md
90. 子集 II 78. 子集题的扩展,其中的元素可能会出现重复了 我们仍沿用78题的代码,稍作改动即可: 此时需要对nums先排个序,方便我们后面跳过选取相同的子集. 跳过选取相同的子集.当选取完 ...
- leetcode刷题-90子集 II
题目 给定一个可能包含重复元素的整数数组 nums,返回该数组所有可能的子集(幂集). 说明:解集不能包含重复的子集. 示例: 输入: [1,2,2]输出:[ [2], [1], [1,2,2], [ ...
- leetcode 90. 子集 II JAVA
题目: 给定一个可能包含重复元素的整数数组 nums,返回该数组所有可能的子集(幂集). 说明:解集不能包含重复的子集. 示例: 输入: [1,2,2] 输出: [ [2], [1], [1,2,2] ...
- Leetcode 90.子集
子集 给定一个可能包含重复元素的整数数组 nums,返回该数组所有可能的子集(幂集). 说明:解集不能包含重复的子集. 示例: 输入: [1,2,2] 输出: [ [2], [1], [1,2,2], ...
- Leetcode 90. 子集 II
地址 https://leetcode-cn.com/problems/subsets-ii/ 给定一个可能包含重复元素的整数数组 nums,返回该数组所有可能的子集(幂集). 说明:解集不能包含重 ...
- LeetCode 90. 子集 II(Subsets II)
题目描述 给定一个可能包含重复元素的整数数组 nums,返回该数组所有可能的子集(幂集). 说明:解集不能包含重复的子集. 示例: 输入: [1,2,2] 输出: [ [2], [1], [1,2,2 ...
随机推荐
- 2019-2020-2 《网络对抗技术》Exp0 环境搭建-Kali Linux 的安装
2019-2020-2 20175334 环境搭建-Kali Linux 的安装 一.Kali的下载与安装 在Kali官网中下载镜像文件 打开Vmware开始创建新虚拟机 选择镜像文件 选择操作系统 ...
- 最大流算法之Ford-Fulkerson算法与Edmonds–Karp算法
引子 曾经很多次看过最大流的模板,基础概念什么的也看了很多遍.也曾经用过强者同学的板子,然而却一直不会网络流.虽然曾经尝试过写,然而即使最简单的一种算法也没有写成功过,然后对着强者大神的代码一点一点的 ...
- 将HTML保存为PDF
使用的是 jsPDF 引用 <script src="https://code.jquery.com/jquery-git.js"></script> ...
- win下删除EFI分区
管理员身份,在cmd终端下,用"diskpart"命令. diskpart ##命令进入Microsoft DiskPart 模式 list disk ##展示磁盘分区列表 sel ...
- Python的字典、列表合并
字典合并: 在日常工作中需要对字典进行合并操作,下面提供几个操作方法 1.使用dict(a,**b) 例: >>> a={'a':1,'b':2} >>> b={' ...
- [CQOI2012] 交换棋子 - 费用流
有一个n行m列的黑白棋盘,你每次可以交换两个相邻格子(相邻是指有公共边或公共顶点)中的棋子,最终达到目标状态.要求第i行第j列的格子只能参与mi,j次交换. Solution 一个点拆三份,入点,主点 ...
- WordPress 背后的故事竟然是这样
原文链接:The Story Behind the New WordPress.com 译者:杰微刊-Leo Xu 一年半以前,我们对使用 WordPress 构建网站所需要采用的技术和开发流程进行大 ...
- createElement(九)
Vue.js 利用 createElement 方法创建 VNode,它定义在 src/core/vdom/create-elemenet.js 中: // wrapper function for ...
- GitBook的使用方式,快速创建网页文档
环境需求:node npm 得装好 ----------------------------------- 我一开始不知道得先装gitbook-cli 先执行了 npm install gitbook ...
- SpringMVC-简单参数绑定
SpringMVC-简单参数绑定 众所周知,springmvc是用来处理页面的一些请求,然后将数据再通过视图返回给用户的,前面的几篇博文中使用的都是静态数据,为了能快速入门springmvc,在 ...