赞
踩
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 组合项 不同的地方,其余思路大体相同,代码如下:
解法一
- class Solution {
- public:
- vector<vector<int> > permute(vector<int> &num) {
- vector<vector<int> > res;
- vector<int> out;
- vector<int> visited(num.size(), 0);
- permuteDFS(num, 0, visited, out, res);
- return res;
- }
- void permuteDFS(vector<int> &num, int level, vector<int> &visited, vector<int> &out, vector<vector<int> > &res) {
- if (level == num.size()) res.push_back(out);
- else {
- for (int i = 0; i < num.size(); ++i) {
- if (visited[i] == 0) {
- visited[i] = 1;
- out.push_back(num[i]);
- permuteDFS(num, level + 1, visited, out, res);
- out.pop_back();
- visited[i] = 0;
- }
- }
- }
- }
- };

还有一种递归的写法,更简单一些,这里是每次交换num里面的两个数字,经过递归可以生成所有的排列情况,代码如下:
解法二
- class Solution {
- public:
- vector<vector<int> > permute(vector<int> &num) {
- vector<vector<int> > res;
- permuteDFS(num, 0, res);
- return res;
- }
- void permuteDFS(vector<int> &num, int start, vector<vector<int> > &res) {
- if (start >= num.size()) res.push_back(num);
- for (int i = start; i < num.size(); ++i) {
- swap(num[start], num[i]);
- permuteDFS(num, start + 1, res);
- swap(num[start], num[i]);
- }
- }
- };

类似题目:
转自:https://www.cnblogs.com/grandyang/p/4358848.html
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。