题解 | #有重复项数字的全排列#

有重复项数字的全排列

http://www.nowcoder.com/practice/a43a2b986ef34843ac4fdd9159b69863

class Solution {
private:
    vector<vector<int>> res;
    vector<int> path;
public:
    vector<vector<int> > permuteUnique(vector<int> &num) {
        sort(num.begin(), num.end());
        
        int n = num.size();
        vector<int> vis(n, 0);
        
        dfs(num, vis);
        return res;
    }
    
    void dfs(vector<int>& num, vector<int>& vis){
        if(path.size() == num.size()){
            res.push_back(path);
            return;
        }
        
        for(int i=0; i<num.size(); i++){
            if(vis[i] == 1){
                continue;
            }
            if(i>0 && num[i] == num[i-1] && vis[i-1] == 0){
                continue;
            }
            path.push_back(num[i]);
            vis[i] = 1;
            dfs(num, vis);
            vis[i] = 0;
            path.pop_back();
        }
        
    }
};
全部评论

相关推荐

点赞 评论 收藏
分享
我面试,她问我有女朋友没
不太迷人的反派_:不过对象,还会结合你老家,意向城市等等,看你是否稳定。哥们,别多想
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务