字符串的排列(剑指offer-27)

题目描述

输入一个字符串,按字典序打印出该字符串中字符的所有排列。例如输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc,acb,bac,bca,cab和cba。
输入描述:
输入一个字符串,长度不超过9(可能有字符重复),字符只包括大小写字母。

题目解析


首先确定一个初始位置,然后通过递归去查找每一个位置的字符可能出现情况。比如说现在要找index下标位置的字符,那么体现在代码中就是交换index以及index位置之后的那些字符。

题目解答

import java.util.*;
public class StringSort {
    public ArrayList<String> Permutation(String str) {
        char[] a = str.toCharArray();
        ArrayList<String> ans = new ArrayList<>();
        solve(ans,a,0,str.length());
        ans = new ArrayList<String>(new HashSet<String>(ans));//去重
        Collections.sort(ans);//字典排序 -> ans.sort(null);
        return ans;
    }

    private void solve(ArrayList<String> ans, char[] a, int index, int length) {//进行全排列
        if (index == length-1){//当前位置在字符串的最后
            String res = change(a);//将char转换成String类型的函数
            ans.add(res);
        }
        else{//现在要确定index位置的字符,将index与index以后的字符进行交换
            for (int i = index; i < length; i++) {
                char tmp = a[i];
                a[i] = a[index];
                a[index] = tmp;
                //当前index位置的字符已经通过交换找到,递归寻找下一个位置的字符
                solve(ans,a,index+1,length);
                //为了消除当前层去递归的时候的进行交换字符的影响,
                //如果不消除的话,那么就会造成原index位置的字符发生变化
                tmp = a[i];
                a[i] = a[index];
                a[index] = tmp;
            }
        }
    }

    private String change(char[] a) {//将char转换成String类型的函数
        StringBuilder res = new StringBuilder();
        for (char value:a
             ) {
                res.append(value
                );
        }
        return res.toString();

    }
}

原文地址:https://www.cnblogs.com/yzhengy/p/13253164.html