面试题 08.08. 有重复字符串的排列组合【 力扣(LeetCode) 】

文章目录

零、原题链接

面试题 08.08. 有重复字符串的排列组合

一、题目描述

有重复字符串的排列组合。编写一种方法,计算某字符串的所有排列组合。

二、测试用例

示例 1:

cpp 复制代码
 输入:S = "qqe"
 输出:["eqq","qeq","qqe"]

示例 2:

cpp 复制代码
 输入:S = "ab"
 输出:["ab", "ba"]

提示:

cpp 复制代码
字符都是英文字母。
字符串长度在[1, 9]之间。

三、解题思路

  1. 基本思路:
      使用回溯法,在利用散列表去重
  2. 具体思路:
    • 编写 dfs 函数
      • 如果字符串每个位置的元素都确定,则记录字符串到答案中。
      • 创建散列表
      • 确定第 k 个位置的字符,从第 k+1 到尾部选取一个字符进行交换
        • 如果散列表中存在该字符,表示重复,则跳过
        • 散列表记录该字符
        • 与第 k 个位置的字符交换
        • 递归确定第 k+1 个字符
        • 恢复状态
    • 调用 dfs 函数,返回结果。

四、参考代码

时间复杂度: O ( n ! ) \Omicron(n!) O(n!)【n 是字符串长度】

空间复杂度: O ( n ) \Omicron(n) O(n)

cpp 复制代码
class Solution {
public:
    string str;
    vector<string> ans;

    void dfs(const int& k) {
        if (k == str.length()) {
            ans.emplace_back(str);
            return;
        }

        vector<bool> m(128, false);
        for (int i = k; i < str.length(); i++) {
            if (m[str[i]])
                continue;
            m[str[i]] = true;
            swap(str[k], str[i]);
            dfs(k+1);
            swap(str[k], str[i]);
        }
    }

    vector<string> permutation(string S) {
        str = S;

        dfs(0);

        return ans;
    }
};
相关推荐
小吴同学·14 分钟前
OPC Client第6讲(wxwidgets):Logger.h日志记录文件(单例模式);登录后的主界面
开发语言·c++·单例模式·wxwidgets
小O的算法实验室18 分钟前
【算法应用】虚拟力算法VFA用于WSN覆盖,无人机网络覆盖问题
算法·wsn覆盖·无人机覆盖
想睡hhh28 分钟前
Practice 2025.6.1—— 二叉树进阶面试题(2)
c++·算法·二叉树·遍历
夜泉_ly42 分钟前
Qt -使用OpenCV得到SDF
c++·qt·算法
?!7142 小时前
算法打卡第11天
数据结构·c++·算法·哈希算法
?!7145 小时前
Socket编程之TCP套件字
linux·网络·c++·网络协议·tcp/ip
小指纹6 小时前
2025山东CCPC题解
c++·算法
技术程序猿华锋7 小时前
Void:免费且隐私友好的 AI 编码利器,挑战 Cursor 地位?
c++·人工智能·mfc
倔强的石头1068 小时前
【C++指南】C++ list容器完全解读(二):list模拟实现,底层架构揭秘
c++·架构·list
PixelMind9 小时前
【LUT技术专题】图像自适应3DLUT
图像处理·深度学习·算法·3dlut