面试题 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;
    }
};
相关推荐
黑听人10 分钟前
【力扣 中等 C】983. 最低票价
c语言·开发语言·数据结构·算法·leetcode
lsnm34 分钟前
【LINUX网络】网络socet接口的基本使用以及实现简易UDP通信
linux·网络·c++·网络协议·ubuntu·udp·centos
扫地僧9851 小时前
免费1000套编程教学视频资料视频(涉及Java、python、C C++、R语言、PHP C# HTML GO)
java·c++·音视频
青春:一叶知秋1 小时前
【C++开发】CMake构建工具
java·开发语言·c++
KIDAKN2 小时前
JavaEE->多线程2
java·算法·java-ee
uwvwko2 小时前
数据结构学习——树的储存结构
数据库·学习·算法·
程序员弘羽2 小时前
C++ 第二阶段:类与对象 - 第三节:成员函数与访问权限
开发语言·c++
森焱森2 小时前
基于GD32F4XX串口环形缓冲区,北斗2.1协议,RD模块数据解析代码
c语言·单片机·算法·架构
我命由我123452 小时前
C++ - 标准库之 <string> npos(npos 概述、npos 的作用)
服务器·c语言·开发语言·c++·后端·visualstudio·visual studio
秋风&萧瑟2 小时前
【C++】C++枚举、const、static的用法
c++·算法