54 回溯算法求解全排列问题

问题描述:给定一个没有重复数字的序列nums,返回其所有可能的全排列。

回溯算法求解:最多进行nums.length次深度的dfs递归,每一次都从剩下未选择序列里面选取一个进行递归,使用used数组进行保存当前是否选取;

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

相关推荐

  1. 54 回溯算法求解排列问题

    2023-12-21 18:48:02       58 阅读
  2. 回溯算法排列

    2023-12-21 18:48:02       30 阅读
  3. LeetCode-排序回溯算法

    2023-12-21 18:48:02       36 阅读
  4. DFS算法 排列问题

    2023-12-21 18:48:02       30 阅读
  5. 46. 排列回溯

    2023-12-21 18:48:02       54 阅读
  6. 【Python小练】回溯法解排列问题

    2023-12-21 18:48:02       34 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-21 18:48:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-21 18:48:02       100 阅读
  3. 在Django里面运行非项目文件

    2023-12-21 18:48:02       82 阅读
  4. Python语言-面向对象

    2023-12-21 18:48:02       91 阅读

热门阅读

  1. 考虑泄流效应的光伏并网点电压系统侧无功优化

    2023-12-21 18:48:02       56 阅读
  2. Leetcode的AC指南 —— 哈希表:202. 快乐数

    2023-12-21 18:48:02       84 阅读
  3. React中的useSearchParams钩子

    2023-12-21 18:48:02       62 阅读
  4. xlsx-style使用中常见问题及解决办法

    2023-12-21 18:48:02       59 阅读
  5. 在服务器上使用“nohup”命令运行Jupyter Notebook

    2023-12-21 18:48:02       58 阅读
  6. Android ViewModel的简单应用

    2023-12-21 18:48:02       48 阅读
  7. 力扣56. 合并区间

    2023-12-21 18:48:02       46 阅读