ITPub博客

首页 > 应用开发 > Java > Java递归算法的使用

Java递归算法的使用

原创 Java 作者:好程序员 时间:2020-07-20 14:25:09 0 删除 编辑

  好程序员Java 培训分享 Java 递归算法的使用, 1 java 递归算法基本思路, Java 递归算法是基于 Java 语言实现的递归算法。递归算法是一种直接或者间接调用自身函数或者方法的算法。递归算法实质是把问题分解成规模缩小的同类问题的子问题,然后递归调用方法表示问题的解。递归往往能给我们带来非常简洁非常直观的代码形式,从而使我们的编码大大简化,然而递归的思维确实跟我们的常规思维相逆的,通常都是从上而下的思维问题,而递归趋势从下往上的进行思维。

  2 java 递归算法解决问题的特点

  递归就是方法里调用自身

  在使用递归策略时,必须有一个明确的递归结束条件,称为递归出口

  递归算法代码显得很简洁,但递归算法解题的运行效率较低。所以不提倡用递归设计程序。

  在递归调用的过程中系统为每一层的返回点、局部量等开辟了栈来存储。递归次数过多容易造成栈溢出等,所以一般不提倡用递归算法设计程序。

  在做递归算法的时候,一定把握出口,也就是做递归算法必须要有一个明确的递归结束条件。这一点是非常重要的。其实这个出口就是一个条件,当满足了这个条件的时候我们就不再递归了。

  3 java 递归算法代码示例:

  public class Factorial {

  //this is a recursive function

  int fact(int n){

  if (n==1) return 1;

  return fact(n-1)*n;

  }

  }

  public class TestFactorial {

  public static void main(String[] args) {

  // TODO Auto-generated method stub

  Factorial factorial=new Factorial();

  System.out.println("factorial(5)="+factorial.fact(5));

  }

  }


来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/69913864/viewspace-2705614/,如需转载,请注明出处,否则将追究法律责任。

请登录后发表评论 登录
全部评论

注册时间:2019-03-20

  • 博文量
    342
  • 访问量
    154353