java实现字符串的全排列

 更新时间:2018年02月05日 10:04:54   作者:snow_7  
这篇文章主要为大家详细介绍了java实现字符串的全排列,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

字符串的全排列,具体内容如下

输入一个字符串,按字典序打印出该字符串中字符的所有排列。例如输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc,acb,bac,bca,cab和cba。 结果请按字母顺序输出。

采用递归的思想:

把需要全排列的字符串分为两部分看待:
(1)字符串的第一个字符;
(2)第一个字符后面的所有字符;

求所有可能出现在第一个位置的字符;将第一个字符和后面的字符一次交换;

固定第一个字符,对第一个字符后面的所有字符求全排列。第一个字符后面的所有字符又可以分为两部分;

java代码: 

import java.util.ArrayList; 
import java.util.TreeSet; 
public class Solution { 
  public ArrayList<String> Permutation(String str) { 
    ArrayList<String> res = new ArrayList<String>(); 
    if(str==null||str.length()==0) 
    { 
      return res; 
    } 
    char[] charArray = str.toCharArray(); 
    //输出按照输入字典顺序 
    TreeSet<String> tempRes = new TreeSet<String>(); 
    PermutationCore(charArray,tempRes,0); 
    res.addAll(tempRes); 
    return res; 
     
  } 
  private void PermutationCore( char[] charArray,TreeSet<String> tempRes,int loc) 
  { 
    if(charArray==null || charArray.length==0 || loc<0 || loc>charArray.length-1) 
    { 
      return ; 
    } 
    if(loc==charArray.length-1) 
    { 
      tempRes.add(String.valueOf(charArray));//递归的出口 
    } 
    else 
    { 
      for(int i=loc;i<charArray.length;i++) 
      { 
        swap(charArray,i,loc);//将第一个字符与后面的字符交换 
        PermutationCore(charArray,tempRes,loc+1);//对后面所有的字符进行全排列 
        swap(charArray,i,loc);//再将之前交换的字符交换回来,以便第一个字符再与其他字符交换 
      } 
        
    } 
  } 
  private void swap(char[] charArray,int i,int j) 
  { 
    char temp = charArray[i]; 
    charArray[i] = charArray[j]; 
    charArray[j] = temp; 
  } 
} 

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • idea+ springboot热部署的配置方法

    idea+ springboot热部署的配置方法

    这篇文章主要介绍了idea+ springboot熱部署的配置方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-05-05
  • Springboot3整合Mybatis-plus3.5.3报错问题解决

    Springboot3整合Mybatis-plus3.5.3报错问题解决

    在日常学习springboot3相关的代码时,在使用 SpringBoot3 整合 MyBatisplus 时出现了一些问题,花了不少时间处理,这篇文章主要介绍了Springboot3整合Mybatis-plus3.5.3报错问题解决,需要的朋友可以参考下
    2023-11-11
  • JavaMail入门教程之创建邮件(2)

    JavaMail入门教程之创建邮件(2)

    这篇文章主要介绍了JavaMail入门教程之创建邮件的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-11-11
  • 使用@RequiredArgsConstructor注解来取代繁琐的@Autowrired

    使用@RequiredArgsConstructor注解来取代繁琐的@Autowrired

    有了@RequiredArgsConstructor注解,我们就可以减少@Autowired的书写,本文主要介绍了使用@RequiredArgsConstructor注解来取代繁琐的@Autowrired,感兴趣的可以了解一下
    2022-04-04
  • 深入分析JAVA流程控制语句

    深入分析JAVA流程控制语句

    这篇文章主要介绍了JAVA流程控制语句的的相关资料,文中讲解非常细致,代码帮助大家更好的理解和学习,感兴趣的朋友可以了解下
    2020-06-06
  • java对接微信小程序详细流程(登录&获取用户信息)

    java对接微信小程序详细流程(登录&获取用户信息)

    这篇文章主要给大家介绍了关于java对接微信小程序(登录&获取用户信息)的相关资料,我们在开发微信小程序时经常需要获取用户微信用户名以及头像信息,微信提供了专门的接口API用于返回这些信息,需要的朋友可以参考下
    2023-08-08
  • 配置java环境变量(linux mac windows7)

    配置java环境变量(linux mac windows7)

    本文给大家详细总结介绍了Linux、MAC以及Windows下配置java环境变量的方法,非常的细致全面,有需要的小伙伴可以参考下
    2015-11-11
  • Java实现动态代理

    Java实现动态代理

    本文给大家介绍的是java使用动态代理类实现动态代理的方法和示例,这里推荐给大家,有需要的小伙伴参考下吧
    2015-02-02
  • Java基于HttpClient实现RPC的示例

    Java基于HttpClient实现RPC的示例

    HttpClient可以实现使用Java代码完成标准HTTP请求及响应。本文主要介绍了Java基于HttpClient实现RPC,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-10-10
  • Java string类型转换成map代码实例

    Java string类型转换成map代码实例

    这篇文章主要介绍了Java string类型转换成map代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-03-03

最新评论