有重复字符串的排列组合

题目链接

有重复字符串的排列组合

题目描述

注意点

  • 字符都是英文字母
  • 字符串长度在[1, 9]之间

解答思路

  • 本题与无重复字符串的排列组合类似,区别是字符串中有重复字符,所以组合数量不会是固定的n * (n - 1) * (n - 2) * ... * 1
  • 首先想到的仍然是深度优先遍历,区别是结果集中同一个位置相同的字符只能添加一次(字符可能在s的不同位置),所以可以使用map存储每个字符和字符的出现次数,对每个位置需要加入的字符可以遍历map的key集合,每个位置能否加入字符c可以根据上一次dfs传入的map.get©判断是否还有剩余的c可以使用

代码

java 复制代码
class Solution {
    int n;
    public String[] permutation(String s) {
        n = s.length();
        List<String> list = new ArrayList<>();
        Map<Character, Integer> map = new HashMap<>();
        for (char c : s.toCharArray()) {
            map.put(c, map.getOrDefault(c, 0) + 1);
        }
        dfs(s, 0, map, new StringBuilder(), list);
        return list.toArray(new String[list.size()]);
    }

    public void dfs(String s, int depth, Map<Character, Integer> map, StringBuilder sonRes, List<String> list) {
        if (depth >= n) {
            list.add(sonRes.toString());
            return;
        }
        for (Character c : map.keySet()) {
            if (map.get(c) == 0) {
                continue;
            }
            sonRes.append(c);
            map.put(c, map.get(c) - 1);
            dfs(s, depth + 1, map, sonRes, list);
            sonRes.deleteCharAt(sonRes.length() - 1);
            map.put(c, map.get(c) + 1);
        }
    }
}

关键点

  • 深度优先遍历的思想
  • 保证结果集中每个位置相同的字符只会考虑一次
相关推荐
庞轩px1 天前
第七篇:Spring扩展点——如何优雅地介入Bean的创建流程
java·后端·spring·bean·aware·扩展点
孬甭_1 天前
初识数据结构与算法
数据结构
tongluowan0071 天前
一个请求在Spring MVC 中是怎么流转的
java·spring·mvc
hoiii1871 天前
孤立森林 (Isolation Forest) 快速异常检测系统
算法
夜郎king1 天前
Spring AI 对接大模型开发易错点总结与实战解决办法
java·人工智能·spring
oradh1 天前
Oracle数据库中的Java概述
java·数据库·oracle·sql基础·oracle数据库java概述
组合缺一1 天前
Java AI 框架三国杀:Solon AI vs Spring AI vs LangChain4j 深度对比
java·人工智能·spring·ai·langchain·llm·solon
c++之路1 天前
适配器模式(Adapter Pattern)
java·算法·适配器模式
吴声子夜歌1 天前
Java——接口的细节
java·开发语言·算法
阿拉金alakin1 天前
深入理解 Java 锁机制:CAS 原理、synchronized 优化与主流锁策略全总结
java·开发语言