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

有重复项数字的全排列

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

/**
 * 
 * @param num int整型一维数组 
 * @return int整型二维数组
 */
function permuteUnique( num ) {
    num.sort((a, b) => a - b);

    let res = [], track = [], used = Array(num.length).fill(false);

    function backTrack(num, track) {
        if(track.length === num.length) {
            res.push([...track]);
            return;
        }

        for(let i = 0; i < num.length; i++) {
            // used[i] 如果已经使用过了,就跳过
            // 如果当前取的数和前一个数一样,也跳过。 !used[i-1] 特别标记是另外一条分支走完的情况
            if(used[i] || (i > 0 && num[i] === num[i-1] && !used[i - 1])) continue

            track.push(num[i]);
            used[i] = true;

            backTrack(num, track);
            
            track.pop();
            used[i] = false;
        }
    }

    backTrack(num, track, 0);

    return res;
}

Array.prototype.top = function () {
    return this[this.length -1];
}

module.exports = {
    permuteUnique : permuteUnique
};

思路:

这道题和那道没有重复项数字的全排列做法一致,只是需要添加一个used标记那个数字用到了还是没用到。

回溯法遍历其实就是便利一颗多叉树,画出多叉树就会清楚多一些:

1,1,2

1,2,1

遍历到第二个1的时候,发现 num[i] === num[i-1] 和前一个1相等了(后续结点情况会重复),并且前面的1的分支已经走完了,这第二个1就跳过。

2,1,1

遍历结点2的时候,走完了左边的分支,到了右边的分支,此时又发现和前面的遍历元素相等了num[i] === num[i-1] (同级结点),那后续结点的遍历又没有必要了。

所以最终遍历结果就是[[1,1,2], [1,2,1], [2,1,1]]

全部评论

相关推荐

路过的周先森:我就喜欢这种无限复活+筛选快的,比那些投进去就没声还占用投递次数的好多了
投递快手等公司7个岗位
点赞 评论 收藏
分享
来,说点可能被同行“骂”的大实话。🙊当初接数字马力Offer时,朋友都说:“蚂蚁的“内包”公司?你想清楚啊!”但入职快一年后的今天,我反而对他有了不一样的看法!🔹&nbsp;是偏见?还是信息差!之前没入职之前外面都在说什么岗位低人一等这类。实际上:这种情况不可至否,不能保证每个团队都是其乐融融。但我在的部门以及我了解的周边同事都还是十分好相处的~和蚂蚁师兄师姐之间也经常开一些小玩笑。总之:身份是蚂蚁公司给的,地位是自己挣的(一个傲娇女孩的自述)。🔹&nbsp;待遇?玩的就是真实!试用期工资全额发!六点下班跑得快(早9晚6或者早10晚7,动态打卡),公积金顶格交。别听那些画饼的,到手的钱和下班的时间才是真的(都是牛马何必难为牛马)。🔹&nbsp;能不能学到技术?来了就“后悔”!我们拥有权限直通蚂蚁知识库,技术栈多到学不完。说“学不到东西”的人,来了可能后悔——后悔来晚了(哈哈哈哈,可以不学但是不能没有)!💥&nbsp;内推地址:https://app.mokahr.com/su/ueoyhg❗我的内推码:NTA6Nvs走我的内推,可以直达业务部门,面试流程更快速,进度可查!今天新放HC,之前挂过也能再战!秋招已经正式开始啦~机会就摆在这,敢不敢来试一试呢?(和我一样,做个勇敢的女孩)
下午吃泡馍:数字马力的薪资一般哇,5年经验的java/测试就给人一万出头,而且刚入职第三天就让人出差,而且是出半年
帮你内推|数字马力 校招
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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