题解 | #字符串的排列#

字符串的排列

http://www.nowcoder.com/practice/fe6b651b66ae47d7acce78ffdd9a96c7

import java.util.*;

class Solution {
    StringBuffer sf = new StringBuffer();
    Set<String> set = new HashSet<>();
    public ArrayList<String> Permutation(String str) {
        ArrayList<String> alist = new ArrayList<>();
        Permutate(str.toCharArray());
        for(String s:set){
            alist.add(s);
        }
        return alist;

    }
    public void Permutate(char[] c){
        if(c.length<=1){
            sf.append(c[0]);
            set.add(sf.toString());
            sf.delete(sf.length()-1,sf.length());
            return;
        }
        for(int i=0;i<c.length;i++){
            sf.append(c[i]);
            char num[] = new char[c.length-1];
            int index = 0;
            for(int j=0;j<c.length;j++){
                if(j==i)continue;
                num[index++] = c[j];
            }
            Permutate(num);
            sf.delete(sf.length()-1,sf.length());
        }
    }

  
}
全部评论

相关推荐

09-22 15:45
门头沟学院 Java
谁给娃offer我给...:我也遇到了,我说只要我通过面试我就去,实际上我根本就不会去😁
点赞 评论 收藏
分享
09-14 17:23
门头沟学院
故事和酒66:所以说副业很重要,程序员干到40岁,再怎么也赚300万了,吃吃利息也够活下去
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务