LeetCode题目:面试题 08.07. 无重复字符串的排列组合

题目

题目链接:https://leetcode-cn.com/problems/permutation-i-lcci/
题目解析:
主要是用回溯方法递归调用,拿adc举例。
在这里插入图片描述
用递归将切割下来的字符串和已经添加的字符串,继续操作。

代码

class Solution {
	//创建list集合,用来存放答案
    List<String> list=new ArrayList<>();
    //主函数
    public String[] permutation(String S) {
    	//递归函数,将S和空字串传过去
        go(S,"");
        //创建答案字符串数组
    	String[] s = new String[list.size()];
    	for(int i=0;i<list.size();i++)
    		s[i] = list.get(i);
		return s;
    	
        
    }
    //递归函数
	private void go(String s, String str) {
		//如果字符串为空或者字符串剩下一个字符时,将答案放入list集合中并返回
		if(s.equals("")||s.length()==1) {
			//System.out.println(s+" "+str);
			list.add(str+s);
			//System.out.println(list);
			//System.out.println("----");
			return;
		}else {	
			//s3将str变为不变的字符串,防止修改
			final String s3 = str;
			for(int i=0;i<s.length();i++) {
				//创建Stringbuffer对象来连接答案字符串
				StringBuffer sb = new StringBuffer(s3);
				//System.out.println(sb.toString());
				sb.append(s.charAt(i));
				//删除s中已经被添加的字符
				String s2 = s.replaceAll(s.charAt(i)+"", "");
				//System.out.println(s2+" "+sb.toString());
				//继续递归
				go(s2,sb.toString());
			}
		}
		return;
		
	}
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值