剑指Offer_字符串的排序

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

参考思路
       这题是典型的排列组合问题,一般都可以采用递归回溯来解决。其中需要注意的是结果集需要按照升序排序,因此我们选用TreeSet而不是使用HashSet,虽然两者都可以去重。此外还需要一个用来存储访问状态的数组visited[]数组。

回溯条件:
       得到一个排列结果则返回。
状态重置:
       排列长度-1;当前排列结果去掉最后一个字符。

参考代码

import java.util.ArrayList;
import java.util.Arrays;
import java.util.HashSet;
import java.util.TreeSet;
public class Solution {
     private ArrayList<String> res = new ArrayList<>();
	    //用于所有路径的去重
	    private TreeSet<String> paths = new TreeSet<>();
	    //用于记录每一条路径,StringBuilder可以用来实现动态增删
	    private StringBuilder path = new StringBuilder();
	    private int[] visited;
     public ArrayList<String> Permutation(String str) {
	        if(str == null || str.equals("")) {
	        	return res;
	        }
            visited = new int[str.length()];
	        char[] charArr = new char[str.length()];
	        charArr = str.toCharArray();
	        //用于对字符数组排序
	        Arrays.sort(charArr);
	        combination(charArr, 0);
	        res.addAll(paths);
	        return res;
	    }
	    
	    public  void combination(char[] charArr,int length) {
	    	if(length == charArr.length) {
	    		paths.add(path.toString());
	    		return;
	    	}
	    	for (int i = 0; i < charArr.length; i++) {
				if (visited[i] == 0) {
					visited[i] = 1;
					path.append(charArr[i]);
					combination(charArr, length+1);
					
					//下面表示回溯代码,包括状态重置
					visited[i] = 0;
					path.deleteCharAt(path.length()-1);
				}
			}
	    }
	    
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值