`
liufei.fir
  • 浏览: 687556 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

java实现的经典递归算法三例

阅读更多
一、写作此文的原因:
  学过程序设计的朋友都知道,存在自调用的算法称作递归算法。 递归往往能给我们带来非常简洁非常直观的代码形势,从而使我们的编码大大简化,然而递归的思维确实很我们的常规思维相逆的,我们通常都是从上而下的思维问题, 而递归趋势从下往上的进行思维,正由于此,很多人对于递归有着深深的恐惧,我曾经也是如此,如今为把我的经验通过几个经典的例子与初学者共享,故作此文,希望能对需要者有所助益,如若如此,便是幸甚……
  二、递归算法设计的基本思想是:对于一个复杂的问题,把原问题分解为若干个相对简单类同的子问题,继续下去直到子问题简单到能够直接求解,也就是说到了递推的出口,这样原问题就有递推得解。
  关键要抓住的是:
  (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[i];
  System.out.println(cout);
  } else {
  for (i = low; i <= high; i++) {
  char temp = list[low];
  list[low] = list[i];
  list[i] = temp;
  permute(list, low + 1, high);
  temp = list[low];
  list[low] = list[i];
  list[i] = 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[i];
  Combine(a, num - 1, b, i+1, a.length);
  b=b.substring(0, b.length()-1);
  }
  }
  }
  }

分享到:
评论

相关推荐

    用java实现的经典递归算法

    本文主要探讨如何使用Java实现经典递归算法,旨在帮助初学者理解递归的工作原理及其应用。递归算法设计的关键在于将复杂问题分解为相似的子问题,直到子问题简单到可以直接解决。这通常涉及到两个要素:递归出口和...

    java编写的递归算法的经典事例

    ### Java编写的递归算法的经典事例:全排列输出 #### 概述 本文将详细介绍一个用Java编写的递归算法实例,该实例用于实现字符数组的所有可能全排列。通过这个例子,我们可以深入理解递归的基本概念、工作原理以及...

    Java实现用递归算法和非递归算法求解斐波那契数列问题.docx

    在给定的文档标题与描述中,“Java实现用递归算法和非递归算法求解斐波那契数列问题”明确指出了本文将围绕Java编程语言、递归算法与非递归算法以及斐波那契数列三个主要方面展开讨论。下面将对这三个核心概念进行...

    一个经典的递归算法实现

    一个经典的java 实现的递归算法。 可直接 运行main 方法 浏览效果

    java数据结构递归算法

    以下是Java实现八皇后问题的递归算法: ```java public class EightQueens { public static void placeQueens(int row, int[][] board, int[] columns, int[] diagonal1, int[] diagonal2) { // 基本情况:如果...

    Java递归算法构造JSON树形结构

    Java 递归算法构造 JSON 树形结构是指通过 Java 语言使用递归算法将数据库中的菜单表构建成树形的 JSON 格式发送给第三方。这种方法可以将复杂的树形结构数据转换成易于理解和处理的 JSON 格式。 在 Java 中,使用...

    java递归算法

    java递归算法,java递归算法,java递归算法

    Java实现汉诺塔递归算法详解

    汉诺塔问题是一个经典的递归算法问题,它源自印度的一个古老传说,旨在通过演示如何将一组盘子从一根柱子移动到另一根柱子来解释宇宙的起源。在这个问题中,我们有三根柱子A、B和C,以及N个大小不一的盘子,初始时...

    递归算法Java实现

    ### 递归算法Java实现 #### 一、递归算法简介 递归是计算机科学中的一个重要概念,指的是一种函数或过程直接或间接地调用自身的行为。在编程语言中,递归通常用来解决那些可以通过更小规模的问题来解决的大问题。...

    java程序的递归算法

    ### Java程序中的递归算法:列出某个目录下的所有子目录和文件 ...通过以上分析,我们可以看到递归算法在Java中的具体实现方式以及如何利用递归来解决实际问题。希望这篇详细解析能够帮助你更好地理解和运用递归算法。

    5!递归算法和非递归算法

    递归算法和非递归算法 在计算机科学与编程领域中,递归算法与非递归算法是两种非常重要的计算方法。本文将详细介绍这两种算法的特点、应用场景以及如何实现它们,特别针对初学者及面试准备者。 #### 递归算法 ...

    Java中的递归算法

    LCS问题 归并排序 矩阵链乘积问题 N皇后问题 贪心算法 快速排序 二分检索 求最大元素最小元素(分治算法) 求n个数的排列(递归)

    Java递归算法(PPT+PDF+Word)

    文档"Java递归算法.docx"可能包含了关于如何在实际代码中应用递归的例子,例如经典的Fibonacci序列计算、阶乘计算或者二分查找等。这些例子有助于理解递归的工作原理和如何在Java中实现它们。 "Java递归算法.pdf...

    15个典型的递归算法的JAVA实现

    15个典型的递归算法的JAVA实现,求N的阶乘、欧几里德算法(求最大公约数)、斐波那契数列、汉诺塔问题、树的三种递归遍历方式、快速排序、折半查找、图的遍历、归并排序、八皇后问题(回溯、递归)、棋盘覆盖(分治,...

    快速选择非递归与递归算法实现

    以上就是关于快速选择算法的非递归和递归实现的详细介绍。通过合理地选取基准和适当的数据结构,快速选择算法可以在大数据集上提供高效的k-th最小元素查找服务。在Java中的`QuickSelect.java`文件中,应该包含了这些...

    Java二分查找递归算法

    Java二分查找递归算法

Global site tag (gtag.js) - Google Analytics