剑指Offer38:字符串的排列

本文深入探讨了字符串全排列算法的实现,通过递归和字符交换的方法,详细讲解了如何生成一个字符串的所有可能排列组合。文章提供了一个Java实现的例子,包括核心函数和交换函数的定义,展示了算法的工作流程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目:
输入一个字符串,打印出该字符串中字符的所有排列。
例如:输入字符串abc,则打印出由字符a、b、c所能排列出来的所有字符串abc、acb、bac、bca、cab、cba

分析:可将字符串分为两部分,第一部分是第一个字符,第二部分是其他。
依此向下挪动第一个字符,第一个字符与其他不一样的字符调换。重新组合成新的字符串

public class Offer38 {

public void Permutation(String str) {
	char[] ch = str.toCharArray();
	core(ch, 0);
}

private void core(char[] ch, int begin) {
	if(begin == ch.length - 1) {
		System.out.println(new String(ch));
		return;
	}
	core(ch, begin + 1); //先把原始的排序的首位给输出 
	
	for(int i = begin + 1; i < ch.length; i++) {
		if(ch[i] != ch[begin]) { //如果不同位置,结果是一样的,就不交换
			swap(ch, begin, i); //交换当前位的字符
			core(ch, begin + 1);
			swap(ch, begin, i); //输出结束后,要恢复之前的排序
		} 
	}	
}

private void swap(char[] ch, int i, int j) {
	char temp = ch[i];
	ch[i] = ch[j];
	ch[j] = temp;
}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值