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

相关推荐
悟空码字几秒前
无缝集成指南,SpringBoot三步接入华为云短信服务
java·springboot·编程技术·后端开发·华为云短信
bubiyoushang8882 分钟前
基于Q-learning的路径规划MATLAB仿真程序实现
开发语言·matlab
E_ICEBLUE6 分钟前
【2026 最新教程】Java 自动化提取 PDF 表格:从文本到 Excel/CSV 的全场景实现
java·pdf·自动化
C雨后彩虹8 分钟前
无向图染色
java·数据结构·算法·华为·面试
J_HelloWorld9 分钟前
缺页中断:Java高性能存储的隐形推手
java·缺页中断
FAFU_kyp13 分钟前
Rust 结构体(struct)
开发语言·后端·rust
一代明君Kevin学长14 分钟前
记录一个上手即用的Spring全局返回值&异常处理框架
java·网络·python·spring
坚持就完事了15 分钟前
扫描线算法
算法
努力写代码的熊大16 分钟前
深入探索C++关联容器:Set、Map、Multiset与Multimap的终极指南及底层实现剖析
开发语言·c++
鱼跃鹰飞18 分钟前
Leetcode尊享面试100题:252. 会议室
算法·leetcode·面试