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数组。

相关推荐
wellc17 小时前
Spring Boot 热部署
java·spring boot·后端
Yupureki17 小时前
《Linux系统编程》12.基础IO
linux·运维·c语言·开发语言·数据库·c++
淮北49417 小时前
bash下好用的快捷键以及linux常用指令
linux·开发语言·ubuntu·bash
金銀銅鐵17 小时前
[Java] 从 class 文件看动态代理
java·后端
C++ 老炮儿的技术栈17 小时前
两个线程对socket 进行读和写,需要加锁吗
java·服务器·网络
萍萍学习18 小时前
蓝桥杯JAVA-4
java·职场和发展·蓝桥杯
XiYang-DING18 小时前
【LeetCode】LCR 019. 验证回文串 II
算法·leetcode·职场和发展
薛定谔的猫喵喵18 小时前
卸载 Python 3.8 报错 “Could not set file security” 的终极解决方案
开发语言·python
灰色小旋风18 小时前
力扣18 四数之和(C++)
数据结构·算法·leetcode