【剑指Offer】38.字符串的排列

题目

输入一个长度为 n 字符串,打印出该字符串中字符的所有排列,你可以以任意顺序返回这个字符串数组。

例如输入字符串ABC,则输出由字符A,B,C所能排列出来的所有字符串ABC,ACB,BAC,BCA,CBA和CAB。

数据范围:n<10

要求:空间复杂度O(n!),时间复杂度 O(n!)

输入描述:

输入一个字符串,长度不超过10,字符只包括大小写字母。

示例1

输入:"ab"

返回值:["ab","ba"]

说明:返回["ba","ab"]也是正确的

示例2

输入:"aab"

返回值:["aab","aba","baa"]

示例3

输入:"abc"

返回值:["abc","acb","bac","bca","cab","cba"]

示例4

输入:""

返回值:[""]

解答

源代码

java 复制代码
import java.util.*;
public class Solution {
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param str string字符串 
     * @return string字符串ArrayList
     */
    public ArrayList<String> Permutation (String str) {
        // write code here
        ArrayList<String> res = new ArrayList<String>();

        if (str == null) {
            return res;
        }

        char[] charStr = str.toCharArray();
        Arrays.sort(charStr);
        boolean[] vis = new boolean[str.length()];
        StringBuffer temp = new StringBuffer();
        recursion(res, charStr, temp, vis);

        return res;
    }

    public void recursion(ArrayList<String> res, char[] str, StringBuffer temp, boolean[] vis) {
        if (temp.length() == str.length) {
            res.add(temp.toString());
            return;
        }

        for (int i = 0; i < str.length; i++) {
            // 这个字符串已经访问过
            if (vis[i]) {
                continue;
            }

            if (i > 0 && str[i - 1] == str[i] && vis[i - 1]) {
                continue;
            }

            temp.append(str[i]);
            vis[i] = true;

            recursion(res, str, temp, vis);

            temp.deleteCharAt(temp.length() - 1);
            vis[i] = false;
        }
    }
}

总结

递归+回溯。

将字符串转化为字符数组,进行递归回溯,递归过程中需要维护一个数组 vis 来记录各个字符是否被遍历过,用 temp 记录当前的组合序列。当 temp 的长度与所给的字符串长度相同时,就可以将 temp 加入结果 res 中了。

相关推荐
4277240030 分钟前
IDEA使用git不提示账号密码登录,而是输入token问题解决
java·git·intellij-idea
chengooooooo1 小时前
苍穹外卖day8 地址上传 用户下单 订单支付
java·服务器·数据库
李长渊哦1 小时前
常用的 JVM 参数:配置与优化指南
java·jvm
计算机小白一个1 小时前
蓝桥杯 Java B 组之设计 LRU 缓存
java·算法·蓝桥杯
万事可爱^1 小时前
HDBSCAN:密度自适应的层次聚类算法解析与实践
算法·机器学习·数据挖掘·聚类·hdbscan
大数据追光猿3 小时前
Python应用算法之贪心算法理解和实践
大数据·开发语言·人工智能·python·深度学习·算法·贪心算法
Dream it possible!4 小时前
LeetCode 热题 100_在排序数组中查找元素的第一个和最后一个位置(65_34_中等_C++)(二分查找)(一次二分查找+挨个搜索;两次二分查找)
c++·算法·leetcode
夏末秋也凉4 小时前
力扣-回溯-46 全排列
数据结构·算法·leetcode
南宫生4 小时前
力扣每日一题【算法学习day.132】
java·学习·算法·leetcode
柠石榴4 小时前
【练习】【回溯No.1】力扣 77. 组合
c++·算法·leetcode·回溯