###### tags: `LeetCode` `Medium` `DFS` # LeetCode #46 [Permutations](https://leetcode.com/problems/permutations/) ### (Medium) 給定一個不含重複數字的數組 nums ,返回其所有可能的全排列 。你可以按任意順序返回答案。 --- 排列題與組合題的差別為:組合題只需往後尋找可能解(因為前面的可能解都已經被前面的元素所納入了), 而排列題每一個起始值都需要從頭檢查(因為不同排列視為不同解), 而避免插入重複元素的方法為另開一數組紀錄該元素被使用過與否。 並且, 起始元素為合併不重要, 只要知道那些元素已被使用, 並以遍歷方式考慮所有元素即可, 因此不用傳入任何位置參數至遞迴函式中。 --- ``` class Solution { public: vector<vector<int>> permute(vector<int>& nums) { int n=nums.size(); vector<int> used(n); vector<int> tmp; vector<vector<int>> ans; dfs(nums, used, tmp, ans); return ans; } void dfs(vector<int>& nums, vector<int>& used, vector<int>& tmp, vector<vector<int>>& ans){ if(tmp.size()==nums.size()){ ans.push_back(tmp); return; } for(int i=0;i<nums.size();i++){ if(used[i])continue; used[i]=1; tmp.push_back(nums[i]); dfs(nums, used, tmp, ans); tmp.pop_back(); used[i]=0; } } }; ```