[27.字符串排列] 回溯法的字符串输出顺序详细+容易理解方法

字符串的排列

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

27.字符串的排列

思路:

  1. 建立 ArrayList<> 集合用于输出答案,判断字符串是否为空,若为空直接返回 lists,若不为空则调用 Process() 处理;

  2. Process() 参数分别为:由字符串转为的字符数组、存放结果的 lists、当前索引 i;

  3. Process() 采用回溯法,首先判断是否满足退出条件,若索引 i 到达字符数组最后一位,则判断当前字符串是否在结果 lists 中,若不在则添加,若在则退出;若不满足退出条件,则开始循环处理:定义 j=i,当 j<字符数组长度时,利用 swap() 方法交换 i 与 j 位置的字符,同时回溯调用 Process(),此时的参数为:交换字符位置后的字符数组、存放结果的 lists、当前索引 i +1;处理完毕后,再次调用 swap() 将字符换回;

  4. swap() 方法参数为:字符数组、索引 i、索引 j。作用就是交换 i、j 位置的字符;

  5. 利用这种方法得到的顺序为: // 括号内为 (i,j) ,P(,,i+1)

    1.交换 (0,0),调用 P(,,1);          //此时为"abc"
    
    ​    交换 (1,1),调用 P(,,2);      //此时为"abc"
    
    ​        满足退出条件,添加 "abc";
    
    ​    换回 (1,1);
    
    ​    交换 (1,2),调用 P(,,2);       //此时为"acb"
    
    ​        满足退出条件,添加 "acb";
    
    ​    换回 (1,2),循环结束;          //此时为"abc"
    
    换回 (0,0), j=0 循环结束;
    
    2.交换 (0,1),调用 P(,,1);           //此时为"bac"
    
    ​    交换 (1,1),调用 P(,,2);       //此时为"bac"
    
    ​        满足退出条件,添加 "bac";
    
    ​    换回 (1,1);
    
    ​    交换 (1,2),调用 P(,,2);        //此时为"bca"
    
    ​        满足退出条件,添加 "bca";
    
    ​    换回 (1,2);                             //此时为"bac"
    
    换回 (0,1), j=1 循环结束;           //此时为"abc"
    
    3.交换 (0,2),调用 P(,,1);               //此时为"cba"
    
    ​    交换 (1,1),调用 P(,,2);          //此时为"cba"
    
    ​        满足退出条件,添加 "cba";
    
    ​    换回 (1,1);
    
    ​    交换 (1,2),调用 P(,,2);            //此时为"cab"
    
    ​        满足退出条件,添加 "cab";
    
    ​    换回 (1,2);                       //此时为"cba"
    
    换回 (0,2), j=2 循环结束;                //此时为"abc"

知识点:

  1. Collections.sort() 和 Arrays.sort() 的使用:
  • Collections.sort() 针对集合 List,排序类型为 List 对应的类型,实质上调用了Arrays.sort(),其底层是归并排序。
  • Arrays.sort() 针对任意对象,排序类型为传入的对象类,对于 基本类型数组 其底层是快速排序,对于 对象数组 其底层是归并排序。
  1. 返回值类型为 ArrayList<> 时,需要定义为 ArrayList<> 类型;

代码

import java.util.*;
public class Solution {
    public ArrayList<String> Permutation(String str) {
        ArrayList<String> lists = new ArrayList<>();
        if(str.length()==0) return lists;
        PermutationProcess(str.toCharArray(),lists,0);
        Collections.sort(lists);
        return lists;
    }

    private void PermutationProcess(char[] ch , List<String> lists,int i){
        if(i == ch.length-1){
            if(!lists.contains(new String(ch))){
                lists.add(new String(ch));
            }
        }else{
            for(int j=i;j<ch.length;j++){
                swap(ch,i,j);
                PermutationProcess(ch,lists,i+1);
                swap(ch,j,i);
            }
        }
    }
    private void swap(char[] ch,int i ,int j){
        if(i != j){
            char tmp = ch[i];
            ch[i] = ch[j];
            ch[j] = tmp;
        }
    }
}
全部评论

相关推荐

03-03 23:12
已编辑
北京邮电大学 Java
书海为家:我来给一点点小建议,因为毕竟还在学校不像工作几年的老鸟有丰富的项目经验,面试官在面试在校生的时候更关注咱们同学的做事逻辑和思路,所以最好在简历中描述下自己做过项目的完整过程,比如需求怎么来的,你对需求的解读,你想到的解决办法,遇到困难如何找人求助,最终项目做成了什么程度,你从中收获了哪些技能,你有什么感悟。
你的简历改到第几版了
点赞 评论 收藏
分享
03-19 10:36
云南大学 C++
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
正在热议
更多
# 长得好看会提高面试通过率吗? #
3876次浏览 45人参与
# 离家近房租贵VS离家远但房租低,怎么选 #
16896次浏览 137人参与
# 巨人网络春招 #
11527次浏览 224人参与
# 春招至今,你的战绩如何? #
15716次浏览 144人参与
# 你的实习产出是真实的还是包装的? #
3051次浏览 53人参与
# 沪漂/北漂你觉得哪个更苦? #
1553次浏览 41人参与
# MiniMax求职进展汇总 #
25140次浏览 321人参与
# HR最不可信的一句话是__ #
1091次浏览 32人参与
# AI面会问哪些问题? #
946次浏览 23人参与
# 你做过最难的笔试是哪家公司 #
1247次浏览 22人参与
# AI时代,哪个岗位还有“活路” #
2853次浏览 51人参与
# 不考虑薪资和职业,你最想做什么工作呢? #
152905次浏览 889人参与
# 军工所铁饭碗 vs 互联网高薪资,你会选谁 #
8021次浏览 43人参与
# XX请雇我工作 #
51155次浏览 171人参与
# 简历第一个项目做什么 #
32148次浏览 361人参与
# 简历中的项目经历要怎么写? #
311051次浏览 4265人参与
# 投格力的你,拿到offer了吗? #
178337次浏览 891人参与
# 你最满意的offer薪资是哪家公司? #
76978次浏览 375人参与
# 当下环境,你会继续卷互联网,还是看其他行业机会 #
187605次浏览 1123人参与
# AI时代,哪些岗位最容易被淘汰 #
64730次浏览 886人参与
# 如果重来一次你还会读研吗 #
230018次浏览 2011人参与
# 正在春招的你,也参与了去年秋招吗? #
364336次浏览 2642人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务