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

相关推荐
TL滕2 分钟前
从0开始学算法——第十二天(KMP算法练习)
笔记·学习·算法
weixin_462446234 分钟前
EasyExcel 动态修改模板 Sheet 名称:自定义 SheetWriteHandler 拦截器
java·开发语言·easyexcel
Math_teacher_fan6 分钟前
第二篇:核心几何工具类详解
人工智能·算法
汉克老师7 分钟前
CCF-NOI2025第二试题目与解析(第二题、集合(set))
c++·算法·noi·子集卷积·sos dp·mod 异常
赵庆明老师9 分钟前
NET 使用SmtpClient 发送邮件
java·服务器·前端
苏小瀚11 分钟前
[Java EE] HTML·CSS·JavaScript基础
java·java-ee
绝世唐门三哥21 分钟前
使用Intersection Observer js实现超出视口固定底部按钮
开发语言·前端·javascript
李拾叁的摸鱼日常22 分钟前
Spring 框架中 RequestContextHolder 深度解析
java·架构
Ayu阿予30 分钟前
C++从源文件到可执行文件的过程
开发语言·c++
C++业余爱好者31 分钟前
JVM优化入门指南:JVM垃圾收集器(GC)介绍
java·开发语言·jvm