欢迎光临
我们一直在努力

java中如何实现递归排列

java中如何实现递归排列插图

递归排列

递归,俗称“我 调 我 自 己”,如果从数据结构的角度来理解,其实就是栈。

假如我们要求得到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零基础入门栏目推荐,欢迎大家一起来共同学习交流!

赞(0) 捐助本站
未经允许不得转载:爱分享 » java中如何实现递归排列

评论 抢沙发

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址

爱分享,永远免费的PDF电子书、知识、技术等资源的共享交流网站

爱分享精选好货商城爱分享淘宝内购优惠券

所有捐助用于升级服务器和寻找资源,以便更好的服务大家

支付宝扫一扫打赏

微信扫一扫打赏