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

相关推荐
Aaa11111443几秒前
四类地址 逻辑地址 线性地址 虚拟地址 物理地址
java
小则又沐风a1 分钟前
深入了解进程概念 第二章
java·linux·服务器·前端
沐知全栈开发2 分钟前
AngularJS 简介
开发语言
程序猿进阶3 分钟前
OpenClaw Mac 安装教程
java·macos·ai·架构·agent·openclaw
变量未定义~4 分钟前
字符串哈希匹配字符串
数据结构·算法·哈希算法
周末也要写八哥8 分钟前
浅谈二叉树的深度优先搜索(DFS)算法
算法·深度优先
骑士雄师11 分钟前
学生管理系统python版本比对
开发语言·python
basketball61612 分钟前
C++ 的 const 相关知识点总结
开发语言·c++
凯瑟琳.奥古斯特17 分钟前
信号分类与特性解析
java·开发语言·职场和发展
y = xⁿ19 分钟前
20天速通LeetCodeday17:一维动态规划
算法