版权声明
1. 本站文章和资源均来自互联网收集和整理,本站不承担任何责任及版权问题。
2. 相关版权归作者及其公司所有,仅供学习研究用途,请勿用于商业目的。
3. 请于下载后24小时内删除,如果喜欢此资源,请购买正版。
4. 若侵犯您的版权,请发邮件至webmaster@ishare1.cn联系我们,我们确认后将立即删除。
递归排列
递归,俗称“我 调 我 自 己”,如果从数据结构的角度来理解,其实就是栈。
假如我们要求得到A、B、C的排列,流程大概如下:
(0)初始状态,栈内无数据。此时栈外:A、B、C
(1)将A放入栈底。此时栈外:B、C
(2)将B放入栈中。此时栈外:C
(3)将C放入栈中。此时栈外:无,输出第一种排列ABC
(4)将C退栈。此时栈外:C
(5)将B退栈。此时栈外:B、C
(6)将C放入栈中。此时栈外:B
(7)将B放入栈中。此时栈外:无,输出第二种排列ACB
之后依次退栈,回归初始状态,再将B放入栈底,重复动作,即可得到所有排列。
免费视频教程推荐:java视频教程
示例如下:
public class demo{ public static void main(String[] args) { char buf[]={'A','B','C'}; //定义待排列数组 perm(buf,0,buf.length-1); } public static void perm(char[] buf,int start,int end){ if(start==end){//入栈结束条件,执行完该判断语句后开始逐步出栈 for(int i=0;i运行结果:
ABC ACB BAC BCA CBA CAB本文由java零基础入门栏目推荐,欢迎大家一起来共同学习交流!