字符串的排列

  1. 题目:输入一个字符串,按字典序打印出该字符串中字符的所有排列。
  2. 举例:输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc,acb,bac,bca,cab和cba。
  3. 解题思路:基于回溯法思想
    这里写图片描述
  4. 代码
/**
 * 功能:输入一个字符串,按字典序打印出该字符串中字符的所有排列。
 * 举例:字符串:abc, 则所有排列为:abc, acb, bac, bca, cab, cba.
 * @version 1.0
 * @date 2018/8/9
 */
public class StringPermutation {
    public static void main(String[] args) {
        ArrayList<String> a = Permutation("abc");
        System.out.println(a.toString());
    }

    /**
     * 返回该字符串中字符的所有排列
     * @param str 字符串
     */
    public static ArrayList<String> Permutation(String str) {
        ArrayList<String> list = new ArrayList<>();

        char[] cStr = str.toCharArray();
        recursPermutation(list,cStr,0);

        /**
         * 按字典序排序
         */
        Collections.sort(list);
        return list;
    }

    /**
     * 递归置换字符数组,并存储至ArrayList
     * @param list
     * @param cStr 当前字符数组
     * @param fromIndex 开始索引
     */
    public static void recursPermutation(ArrayList<String> list,char[] cStr,int fromIndex){
        /**
         * 终止递归的条件
         */
        if(fromIndex==cStr.length-1){
            String newString = String.valueOf(cStr);
            if(!list.contains(newString)){
                list.add(newString);
            }
            return;
        }

        for(int j=fromIndex;j<cStr.length;j++){
            //第一位(fromIndex)和后面每一位(j)交换
            swap(cStr,fromIndex,j);
            //将指标向前移动一格,让下一格与后面的交换
            recursPermutation(list,cStr,fromIndex+1);
            //复位
            swap(cStr,fromIndex,j);
        }
    }

    /**
     * 交换cStr数组中索引为i和j的元素
     * @param cStr
     * @param i
     * @param j
     */
    public static void swap(char[] cStr,int i,int j){
        char temp = cStr[i];
        cStr[i] = cStr[j];
        cStr[j] = temp;
    }

}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值