54 回溯算法求解全排列问题

问题描述:给定一个没有重复数字的序列nums,返回其所有可能的全排列。

回溯算法求解:最多进行nums.length次深度的dfs递归,每一次都从剩下未选择序列里面选取一个进行递归,使用used数组进行保存当前是否选取;

java 复制代码
public void  tranceBack(int []nums,int used[],int index,LinkedList<Integer>templist,LinkedList<LinkedList<Integer>>res)
{
if(index==nums.length){
res.add(templist);
return ;
}
for(int i=0;i<nums.length;i++)
{
if(used[i])
{
continue;
}else
{
used[i]=true;
templist.add(nums[i]);
tranceBack(nums,used,index+1,templist,res);
used[i]=false;
templist.remove(templist.size()-1);
}
}
}
public List<List<Integer>>TranceBack(int [] nums)
{
List<List<Integer>>res=new LinkedList<LinkedList<Integer>>();
Boolean [] used=new Boolean[nums.length];
tranceBack(nums,used,new LinkedList<Integer>(),res);
​​​​​​​return res;
}

而对于所有子集而言,每一次递归都保存一次结果,for循环从index开始,不需要used数组。

相关推荐
CHANG_THE_WORLD1 分钟前
指针入门一
java·前端·网络
时艰.2 分钟前
订单系统读写分离方案设计与实现
java
瓦特what?3 分钟前
插 入 排 序
开发语言·c++
铸人3 分钟前
再论自然数全加和 - 欧拉伽马常数
数学·算法·数论·复数
014-code7 分钟前
MySQL 事务隔离级别
java·数据库·mysql
踩坑记录16 分钟前
leetcode hot100 200. 岛屿数量 medium dfs
leetcode·深度优先
hrhcode18 分钟前
【Netty】三.ChannelPipeline与ChannelHandler责任链深度解析
java·后端·spring·springboot·netty
m0_5312371721 分钟前
C语言-初始化赋值,函数,变量的作用域与生命周期
c语言·开发语言
m0_5312371726 分钟前
C语言-变量,枚举常量,字符串,打印类型,转义字符
c语言·数据结构·算法
张3蜂26 分钟前
Python venv 详解:为什么要用、怎么用、怎么用好
开发语言·python