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

相关推荐
啊董dong几秒前
noi-2026年5月12号小测验
数据结构·c++·算法
不知名的忻1 分钟前
红黑树(简易版)
算法·红黑树
idingzhi3 分钟前
A股量化策略日报(2026年05月22日)
android·开发语言·python·kotlin
NQBJT4 分钟前
万字拆解 NeckFix:AI 脖子前倾检测的算法原理与工程实现
人工智能·算法
jaychouchannel8 分钟前
Python 常用排序算法详解
算法
数智工坊10 分钟前
【Inner Monologue论文阅读】: 首次将大语言模型嵌入机器人控制闭环,实现自我反思和动态行为调整
论文阅读·人工智能·算法·语言模型·机器人·无人机
金銀銅鐵14 分钟前
[Java] 如何理解 class 文件中字段的 access flags?
java·后端
小短腿的代码世界22 分钟前
Qt国际化深度解析:从源码到企业级多语言实践
java·数据库·qt
江上清风山间明月28 分钟前
如何将python开发的window应用打包成exe
开发语言·python·exe·打包
凌冰_32 分钟前
IDEA 集成Claude Code
java·ide