前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >LeetCode 47. 全排列 II(回溯+搜索剪枝)

LeetCode 47. 全排列 II(回溯+搜索剪枝)

作者头像
Michael阿明
发布2021-02-20 11:08:14
2110
发布2021-02-20 11:08:14
举报
文章被收录于专栏:Michael阿明学习之路

1. 题目信息

给定一个可包含重复数字的序列,返回所有不重复的全排列。

代码语言:javascript
复制
示例:

输入: [1,1,2]
输出:
[
  [1,1,2],
  [1,2,1],
  [2,1,1]
]

来源:力扣(LeetCode)

链接:https://leetcode-cn.com/problems/permutations-ii

著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2. 解题

leetcode46的基础上做修改

类似题目:

LeetCode 491. 递增子序列(回溯+判重)

LeetCode 996. 正方形数组的数目(回溯+剪枝)

  • 先对数组排序
  • 如果前一个数等于后一个数,且前者没有访问过,nums[i-1] == nums[i] && ! visited[i-1],则直接跳过
代码语言:javascript
复制
class Solution {
public:
    vector<vector<int>> permuteUnique(vector<int>& nums) {
        vector<int> row;
        vector<vector<int>> ans;
        bool occurred[nums.size()];
        memset(occurred, 0, sizeof(bool)*nums.size());
        sort(nums.begin(), nums.end());
        bt(nums, 0, occurred, row, ans);
        return ans;
    }
    void bt(vector<int>& nums, int count, bool *occurred, vector<int> row, vector<vector<int>>& ans)
    {
        if(count == nums.size())
        {
            ans.push_back(row);   
            return;
        }
        for(int i = 0; i < nums.size(); ++i)
        {
            if(occurred[i] == false)
            {
                if(i >= 1 && nums[i-1] == nums[i] && !occurred[i-1])
                    continue;	//搜索剪枝
                occurred[i] = true;
                row.push_back(nums[i]);
                bt(nums,count+1,occurred,row,ans);
                row.pop_back();
                occurred[i] = false;
            }
        }
    }
};
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2019/08/28 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. 题目信息
  • 2. 解题
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档