当前位置:   article > 正文

LeetCode--Permutations 全排列_全排列leetcodecsdn

全排列leetcodecsdn

Given a collection of numbers, return all possible permutations.

For example,
[1,2,3] have the following permutations:
[1,2,3][1,3,2][2,1,3][2,3,1][3,1,2], and [3,2,1].

 

这道题是求全排列问题,给的输入数组没有重复项,这跟之前的那道 Combinations 组合项 和类似,解法基本相同,但是不同点在于那道不同的数字顺序只算一种,是一道典型的组合题,而此题是求全排列问题,还是用递归DFS来求解。这里我们需要用到一个visited数组来标记某个数字是否访问过,然后在DFS递归函数从的循环应从头开始,而不是从level开始,这是和 Combinations 组合项 不同的地方,其余思路大体相同,代码如下:

解法一

  1. class Solution {
  2. public:
  3. vector<vector<int> > permute(vector<int> &num) {
  4. vector<vector<int> > res;
  5. vector<int> out;
  6. vector<int> visited(num.size(), 0);
  7. permuteDFS(num, 0, visited, out, res);
  8. return res;
  9. }
  10. void permuteDFS(vector<int> &num, int level, vector<int> &visited, vector<int> &out, vector<vector<int> > &res) {
  11. if (level == num.size()) res.push_back(out);
  12. else {
  13. for (int i = 0; i < num.size(); ++i) {
  14. if (visited[i] == 0) {
  15. visited[i] = 1;
  16. out.push_back(num[i]);
  17. permuteDFS(num, level + 1, visited, out, res);
  18. out.pop_back();
  19. visited[i] = 0;
  20. }
  21. }
  22. }
  23. }
  24. };

还有一种递归的写法,更简单一些,这里是每次交换num里面的两个数字,经过递归可以生成所有的排列情况,代码如下:

解法二


  1. class Solution {
  2. public:
  3. vector<vector<int> > permute(vector<int> &num) {
  4. vector<vector<int> > res;
  5. permuteDFS(num, 0, res);
  6. return res;
  7. }
  8. void permuteDFS(vector<int> &num, int start, vector<vector<int> > &res) {
  9. if (start >= num.size()) res.push_back(num);
  10. for (int i = start; i < num.size(); ++i) {
  11. swap(num[start], num[i]);
  12. permuteDFS(num, start + 1, res);
  13. swap(num[start], num[i]);
  14. }
  15. }
  16. };

类似题目:

Next Permutation

Permutations II



转自:https://www.cnblogs.com/grandyang/p/4358848.html



本文内容由网友自发贡献,转载请注明出处:https://www.wpsshop.cn/w/盐析白兔/article/detail/548211?site
推荐阅读
相关标签
  

闽ICP备14008679号