推广

剑指offer 39- 数字排列

iseeyu2年前 (2024-02-21)推广108

图片来源于网络

时间复杂度分析:

搜索树中最后一层共 个叶节点,在叶节点处记录方案的计算量是 ,所以叶节点处的计算量是
搜索树一共有
个内部节点,在每个内部节点内均会for循环 n 次,因此内部节点的计算量也是 。 所以总时间复杂度是

class Solution {
public:
    vector<vector<int>> res;//结果数组
    vector<bool> st;//状态数组
    vector<int> path;//保存当前路径的数
    vector<vector<int>> permutation(vector<int>& nums) {
        for(int i=0; i<nums.size(); i++) st.push_back(false);
        dfs(nums, 0);
        return res;
    }
    
    void dfs(vector<int>& nums, int u) {
        if (u == nums.size()) {//u==nums.size()说明当前路径结束,返回一种情况
            res.push_back(path);
            return;
        }
        
        for(int i=0; i<nums.size(); i++) {
            if(!st[i]) {
                st[i] = true;
                path.push_back(nums[i]);
                dfs(nums, u+1);
                //从每个分支退回来的时候需要把修改过的状态还原
                st[i] = false; 
                path.pop_back();
            }
        }
    }
};

再看一题可能包含重复数字的

输入一组数字(可能包含重复数字),输出其所有的排列方式。
样例

输入:[1,2,3]

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

分析:
由于有重复元素的存在,这道题的枚举顺序和上次不同。

先将所有数从小到大排序,这样相同的数会排在一起;
从左到右依次枚举每个数,每次将它放在一个空位上;
对于相同数,我们人为定序,就可以避免重复计算:我们在dfs时记录一个额外的状态,记录上一个相同数存放的位置 start,我们在枚举当前数时,只枚举 start+1,start+2,…,n这些位置。
不要忘记递归前和回溯时,对状态进行更新。

时间复杂度:
搜索树中最后一层共 个节点,前面所有层加一块的节点数量相比于最后一层节点数是无穷小量,可以忽略。且最后一层节点记录方案的计算量是 ,所以总时间复杂度是

class Solution {
public:
    vector<vector<int>> res;
    vector<int> st, path;
    vector<vector<int>> permutation(vector<int>& nums) {
        st = vector<int>(nums.size(), false);
        sort(nums.begin(), nums.end());
        path = vector<int>(nums.size());
        dfs(nums, 0, 0);
        return res;
    }
    
    void dfs(vector<int>& nums, int u, int start) {
        if(u == nums.size()) {
            res.push_back(path);
            return;
        }
        if(!u || nums[u] != nums[u-1]) start = 0;
        for(int i=start;i<nums.size();i++) {
            if (!st[i]) {
                st[i] = true;
                path[i] = nums[u];
                dfs(nums, u+1, i+1);
                // 用st[i]表示path[i]是否存在
                // st[i] == false,表示path[i]存在;
                // st[i] == true,表示path[i]不存在;
                // 当st[i] == false时,path[i]下次会被新的值覆盖掉,所以就不需要再remove了。
                st[i] = false;
            }
        }
    }
};

另一种解法:

class Solution {
public:
    vector<vector<int>> res;
    // vector<int> st;
    vector<int> path;
    vector<vector<int>> permutation(vector<int>& nums) {
        // st = vector<int>(nums.size(), false);
        sort(nums.begin(), nums.end());
        // path = vector<int>(nums.size());
        path.resize(nums.size());
        dfs(nums, 0, 0, 0);
        return res;
    }
    
    void dfs(vector<int>& nums, int u, int start, int state) {
        if(u == nums.size()) {
            res.push_back(path);
            return;
        }
        if(!u|| nums[u] != nums[u-1]) start = 0;
        
        for(int i=start;i<nums.size();i++) {
            if(!(state>>i&1)) {
                path[i] = nums[u];
                dfs(nums, u+1, i+1, state+(1<<i));
            }
        }
    }
};

扫描二维码推送至手机访问。

版权声明:本文由西安泽虎代运营发布,如需转载请注明出处。

转载请注明出处https://0291.com.cn/post/57662.html

相关文章

拼多多整体评价:物美价廉,打造全新购物体验

拼多多整体评价:物美价廉,打造全新购物体验

随着互联网的快速发展,电商平台在我国遍地开花,为广大消费者提供了便捷的购物渠道。其中,拼多多作为近年来迅速崛起的电商平台,受到了广泛关注。本文将对拼多多的整体评价进行探讨,分析其优势和不足之处,帮助大家全面了解拼多多。 从价格方面来看,拼多多无疑是物美价廉的代表。平台上的商品价格普遍低于其...

快手短视频产品分析!

快手短视频产品分析!

  短视频已经成为了我们日常生活的一部分,快手与抖音是两大短视频巨头,本文作者对快手的短视频产品进行了深度体验,并从中挖掘一些小细节,我们一起来看下吧。 本文主要分析版本的改动,以及快手在短视频方面的细节设置。 一、产品简介 1. 产品定位 从应用商店简介来看,快手的突...

软文营销风险都有哪些?这五大方面需要注意

在移动互联网时代,社会是未来营销行业的发展趋势,而软文是不可或缺的信息载体。与硬文相比,软文成本更低,效果更好。越来越多的企业也越来越重视的力量。然而,随着软文越来越热,一些风险也会出现。只有学会避免这些风险,软文营销才能发挥其最大价值。今天,我想总结一些避免软文营销风险的...

我来分享一个企业该如何做才会让自己的全网营销更精准。

我来分享一个企业该如何做才会让自己的全网营销更精准。

市场营销学的研究对象以满足客户需求为中心的企业市场营销过程及其规律性,即在特定的市场营销环境中,为满足实现和潜在的客户需求或市场需求,企业以市场调研与分析为基础所实施的以产品、定价、渠道、促销为主要决策内容的市场营销管理过程及其客观规律性。 全网营销战略实施与控制的分析。公司实施全网营销...

淘宝极速推怎么使用(淘宝极速推广有用吗)

淘宝极速推怎么使用(淘宝极速推广有用吗)

无线端和PC端都有展现,在无线端可以在千牛后台搜索极速推,直接找到极速推小程序。PC端直接在商品列表,查看到极速推的入口。是根据通过技术算法,帮助您的商品推荐到您货品潜在的高活消费者链路上。透出的地方比较多所以无法一一列举。...

直播带货拐点已至,薇娅雪梨们释放的流量又将流向何方?

直播带货拐点已至,薇娅雪梨们释放的流量又将流向何方?

编辑导语:最近直播带货的风波不断,薇娅被因偷税漏税被罚,李佳琦被点名,主播们人人自危。少了大主播,直播带货行业即将走向一个新拐点。本文作者对此进行了分析,希望对你有帮助。 13.41亿元,直播带货女王薇娅因偷逃税被追缴并处罚款的金额。 这一天文数据,是税后月薪一万的人需日夜不...

现在,非常期待与您的又一次邂逅

我们努力让每一部企业宣传片和抖音短视频成为商业大片