Java学习者论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

恭喜Java学习者论坛(https://www.javaxxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,购买链接:点击进入购买VIP会员
JAVA高级面试进阶视频教程Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程

Go语言视频零基础入门到精通

Java架构师3期(课件+源码)

Java开发全终端实战租房项目视频教程

SpringBoot2.X入门到高级使用教程

大数据培训第六期全套视频教程

深度学习(CNN RNN GAN)算法原理

Java亿级流量电商系统视频教程

互联网架构师视频教程

年薪50万Spark2.0从入门到精通

年薪50万!人工智能学习路线教程

年薪50万!大数据从入门到精通学习路线年薪50万!机器学习入门到精通视频教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程 MySQL入门到精通教程
查看: 296|回复: 0

[算法学习]java实现的经典递归算法三例

[复制链接]
  • TA的每日心情
    开心
    2021-3-12 23:18
  • 签到天数: 2 天

    [LV.1]初来乍到

    发表于 2014-11-5 00:02:36 | 显示全部楼层 |阅读模式
    一、写作此文的原因:
          学过程序设计的朋友都知道,存在自调用的算法称作递归算法。 递归往往能给我们带来非常简洁非常直观的代码形势,从而使我们的编码大大简化,然而递归的思维确实很我们的常规思维相逆的,我们通常都是从上而下的思维问题, 而递归趋势从下往上的进行思维,正由于此,很多人对于递归有着深深的恐惧,我曾经也是如此,如今为把我的经验通过几个经典的例子与初学者共享,故作此文,希望能对需要者有所助益,如若如此,便是幸甚。。。

    二、递归算法设计的基本思想是:对于一个复杂的问题,把原问题分解为若干个相对简单类同的子问题,继续下去直到子问题简单到能够直接求解,也就是说到了递推的出口,这样原问题就有递推得解。
    关键要抓住的是:

    (1)递归出口

    (2)地推逐步向出口逼近


       
      
       
       
         
       

         
       
      
       三、具体实例

    1。汉诺塔
    这是递归的超经典的例子,几乎每本程序设计书上谈到递归都会介绍。具体情景不再赘述。以我上述的方法观之:(1)递归的出口在于disk数为一的时候

    (2)向出口逼近:如果不是一,是n ,则我们先挪动上面n-1块disk,等上面挪完,即递归返回的时候,我们挪动最底下的disk。

    仅仅如此,一个貌似十分复杂的问题就解决了,因为挪动那n-1块disk的时候,会继续向上减少,直到disk的数量为一为止。下面给出java程序编码(已测试过,运行正常):

    import javax.swing.JOptionPane;

    public class Hanoi {
       private static final String DISK_B = "diskB";
       private static final String DISK_C = "diskC";
       private static final String DISK_A = "diskA";
       static String from=DISK_A;
       static String to=DISK_C;
       static String mid=DISK_B;

       public static void main(String[] args) {
        String input=JOptionPane.showInputDialog("please input the number of the disks you want me move.");
        int num=Integer.parseInt(input);
        move(num,from,mid,to);
       }

       private static void move(int num, String from2, String mid2, String to2) {
         if(num==1){
           System.out.println("move disk 1 from "+from2+" to "+to2);
         }
         else {
           move(num-1,from2,to2,mid2);
           System.out.println("move disk "+num+" from "+from2+" to "+to2);
           move(num-1,mid2,from2,to2);
          }

        }
    }


    2。这是一个排列的例子,它所做的工作是将输入的一个字符串中的所有元素进行排序并输出,例如:你给出的参数是"abc" 则程序会输出:
    abc
    acb
    bac
    bca
    cab
    cba

    (1)算法的出口在于:low=high也就是现在给出的排列元素只有一个时。
    (2)算法的逼近过程:先确定排列的第一位元素,也就是循环中i所代表的元素,
    然后low+1开始减少排列元素,如此下去,直到low=high
    public static void permute(String str) {
         char[] strArray = str.toCharArray();
        permute(strArray, 0, strArray.length - 1);
    }

      public static void permute(char[] list, int low, int high) {
       int i;
       if (low == high) {
          String cout = "";
          for (i = 0; i <= high; i++)
             cout += list;
             System.out.println(cout);
       } else {
         for (i = low; i <= high; i++) {
            char temp = list[low];
            list[low] = list;
            list = temp;
            permute(list, low + 1, high);
            temp = list[low];
            list[low] = list;
            list = temp;
        }
      }
    }

    3.这是一个组合的例子,与上述的例子相似,只是它所做的工作是,输出所给字符串中制定数目的元素的组合种类
    (1)程序出口在于n=1,此时只要输出目标数组的所有元素即可
    (2)逼近过程,当n>1 的时候,我们先取第一个元素放入目标数组中,然后n-1,如此下去,最后出来。
    import javax.swing.JOptionPane;

    public class Combination {

    /**
    * @param args
    */
    public static void main(String[] args) {

        String input = JOptionPane.showInputDialog("please input your String: ");
        String numString = JOptionPane.showInputDialog("please input the number of your Combination: ");
        int num = Integer.parseInt(numString);
        Combine(input, num);
       }

       private static void Combine(String input, int num) {
          char[] a = input.toCharArray();
          String b = "";
          Combine(a, num, b, 0, a.length);
       }

        private static void Combine(char[] a, int num, String b, int low, int high) {
         if (num == 0) {
            System.out.println(b);
         } else {
           for (int i = low; i < a.length; i++) {
             b += a;
             Combine(a, num - 1, b, i+1, a.length);
             b=b.substring(0, b.length()-1);
            }
          }

       }
    }

    由于递归的表述确实不易加上本人的水平有限,颇有以己之昏昏欲人之昭昭的意味,还望大家多多谅解。



      
      
       
       

         
       

         
       
      
    复制代码

    源码下载:http://file.javaxxz.com/2014/11/5/000236109.zip
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|Java学习者论坛 ( 声明:本站资料整理自互联网,用于Java学习者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2025-2-25 13:20 , Processed in 0.401587 second(s), 46 queries .

    Powered by Discuz! X3.4

    © 2001-2017 Comsenz Inc.

    快速回复 返回顶部 返回列表