算法训练营Day29(回溯)
2023-12-28 13:42:51
491.递增子序列
不能和之前去重一样,排序,然后i>startIndex&&nums[i]=nums[i-1]这样子了
class Solution {
List<List<Integer>> result = new ArrayList<>();
List<Integer> path = new ArrayList<>();
public List<List<Integer>> findSubsequences(int[] nums) {
backTracking(nums,0);
return result;
}
void backTracking(int [] nums,int startIndex){
if(path.size()>=2){
result.add(new ArrayList<>(path));
}
if(startIndex==nums.length){
return;
}
HashSet<Integer> set = new HashSet<>();//每层for循环,去重
for(int i = startIndex;i<nums.length;i++){
//两个逻辑,递增和重复取数
if(!path.isEmpty()&&nums[i]<path.get(path.size()-1) || set.contains(nums[i])){
continue;//注意continue,是还可以继续for循环里面的
}
path.add(nums[i]);
set.add(nums[i]);
backTracking(nums,i+1);
path.removeLast();
}
}
}
46.全排列
class Solution {
List<List<Integer>> result = new ArrayList<>();
List<Integer> path = new ArrayList<>();
public List<List<Integer>> permute(int[] nums) {
backTracking(nums);
return result;
}
void backTracking(int [] nums){
if(path.size()==nums.length){
result.add(new ArrayList<>(path));
}
for(int i = 0;i<nums.length;i++){
if(path.contains(nums[i])){
continue;
}
path.add(nums[i]);
backTracking(nums);
path.removeLast();
}
}
}
class Solution {
List<List<Integer>> result = new ArrayList<>();
List<Integer> path = new ArrayList<>();
boolean [] used;
public List<List<Integer>> permute(int[] nums) {
used = new boolean[nums.length];
backTracking(nums);
return result;
}
void backTracking(int [] nums){
if(path.size()==nums.length){
result.add(new ArrayList<>(path));
}
for(int i = 0;i<nums.length;i++){
if(used[i]){
continue;
}
used[i] = true;
path.add(nums[i]);
backTracking(nums);
path.removeLast();
used[i] = false;
}
}
}
47.全排列?II
class Solution {
List<List<Integer>> result = new ArrayList<>();
List<Integer> path = new ArrayList<>();
public List<List<Integer>> permuteUnique(int[] nums) {
boolean[] used = new boolean[nums.length];
Arrays.fill(used, false);
Arrays.sort(nums);
backTracking(nums,used);
return result;
}
void backTracking(int [] nums,boolean [] used){
if(path.size()==nums.length){
result.add(new ArrayList<>(path));
return;
}
for(int i = 0;i<nums.length;i++){
//普通全排列里的不能重复用这个数
if(used[i]==true) continue;
//去重,同一层不重复
if((i > 0 && nums[i] == nums[i - 1]&&used[i-1]==false)) continue;
//正式逻辑
used[i] = true;
path.add(nums[i]);
backTracking(nums,used);
used[i]=false;
path.removeLast();
}
}
}
文章来源:https://blog.csdn.net/weixin_65728526/article/details/135241478
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!