【刷题笔记】leetcode 46.全排列 | 优质解法

10 篇文章 0 订阅
5 篇文章 0 订阅

学习笔记

【刷题笔记】46.全排列|优质解法

思路:回溯

基本盘:

我们每次递归,记录已访问的元素。

从剩下的元素中取,取完回溯。

状态树是每层决定放入一个元素。

新思路

今天复习的时候,看到外国老哥相当精妙的理解。

就来做一个汉化

主要思路有点像插入排序

每次的决定从决定放入哪个元素到决定下一个元素放在哪个位置。

具体来讲,

比如我的输入是[1, 2, 3]

  • 先拿一个[1],剩下[2, 3]
  • 按照顺序,我们拿[2], 我们尝试将[2]放到[1]之前或之后,出现两种情况
    • [1, 2]
    • [2, 1]
  • 我们尝试放[3],那么就有 2 × 3 = 6 2\times 3 = 6 2×3=6 种情况,因为[3]的位置有三种放法,又有两种排列([1, 2][2, 1]
    • 放0位
      • [3, 1, 2]
      • [3, 2, 1]
    • 放1位
      • [1, 3, 2]
      • [2, 1, 3]
    • 放2位
      • [1, 2, 3]
      • [2, 1, 3]
  • 如此,就得到了全排列

实现

如此找位置插入,我们不难对基本的回溯代码做出改造:

class Solution {
public:
    vector<vector<int>> permute(vector<int>& nums) {
        vector<vector<int>>res;
        vector<int>vec;
        DFS(nums, 0, vec, res);
        return res;
    }
    
    void DFS(vector<int>& nums, int pos, vector<int>& vec, vector<vector<int>>& res){
        if(pos == nums.size()){
            res.push_back(vec);
            return;
        }
      	// 遍历vec寻找位置
        for(int i = 0; i <= vec.size(); i++){
            vec.insert(vec.begin() + i, nums[pos]);
          // drill down,找下一个数
            DFS(nums, pos + 1, vec, res);
            vec.erase(vec.begin() + i);
        }
        return;
    }
};

因为是找位置,我们不需要过多的判断来去重

这样就会使得我们的代码更加简洁。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值