⭐算法OJ⭐全排列【回溯】(C++实现)Permutations II

47. Permutations II

Given a collection of numbers, nums, that might contain duplicates, return all possible unique permutations in any order.

Constraints:

  • 1 <= nums.length <= 8
  • -10 <= nums[i] <= 10

Example 1:

复制代码
Input: nums = [1,1,2]
Output:
[[1,1,2],
 [1,2,1],
 [2,1,1]]

Example 2:

复制代码
Input: nums = [1,2,3]
Output: [[1,2,3],[1,3,2],[2,1,3],[2,3,1],[3,1,2],[3,2,1]]

包含重复元素的全排列问题 ,与不包含重复元素的全排列问题不同,需要避免生成重复的排列。使用回溯算法,并通过剪枝来确保生成的排列唯一。

cpp 复制代码
#include <iostream>
#include <vector>
#include <algorithm>

using namespace std;

// 回溯函数
void backtrack(vector<int>& nums, vector<vector<int>>& result, int start) {
    // 如果当前起始位置是数组的最后一个元素,说明找到一个排列
    if (start == nums.size()) {
        result.push_back(nums); // 将当前排列存入结果
        return;
    }

    // 用于记录当前层已经使用过的数字,避免重复
    vector<bool> used(21, false); // 数字范围在 -10 到 10 之间

    // 从起始位置开始,尝试交换元素
    for (int i = start; i < nums.size(); i++) {
        // 如果当前数字已经使用过,跳过
        if (used[nums[i] + 10]) { // +10 是为了将负数映射到正数
            continue;
        }

        used[nums[i] + 10] = true; // 标记当前数字已使用
        swap(nums[start], nums[i]); // 交换元素
        backtrack(nums, result, start + 1); // 递归到下一个位置
        swap(nums[start], nums[i]); // 回溯,撤销交换
    }
}

// 主函数:生成所有唯一排列
vector<vector<int>> permuteUnique(vector<int>& nums) {
    vector<vector<int>> result; // 存储所有唯一排列
    backtrack(nums, result, 0); // 从第 0 个位置开始回溯
    return result;
}
相关推荐
fish_xk17 分钟前
c++中的引用和数组
开发语言·c++
有点。3 小时前
C++ ⼀级 2024 年 03 ⽉
c++
CC.GG4 小时前
【C++】二叉搜索树
java·c++·redis
Savior`L5 小时前
二分算法及常见用法
数据结构·c++·算法
深海潜水员5 小时前
OpenGL 学习笔记 第一章:绘制一个窗口
c++·笔记·学习·图形渲染·opengl
mmz12075 小时前
前缀和问题(c++)
c++·算法·图论
ULTRA??5 小时前
初学protobuf,C++应用例子(AI辅助)
c++·python
旖旎夜光6 小时前
list实现(7)(上)
c++
努力学算法的蒟蒻6 小时前
day27(12.7)——leetcode面试经典150
算法·leetcode·面试
不会c嘎嘎6 小时前
深入理解 C++ 异常机制:从原理到工程实践
开发语言·c++