算法图解之递归
| 图一: 
 ? ?图二: 
 ? ? ? 图一和图二对比,它们的作用都是相同的。从流程上分析,图一流程相对比较复杂,而图二则简单明了, 那么递归和循环之间的区别是什么呢? 相同点: ? 基线条件和递归条件编写递归函数时,必须告诉它何时停止递归。正因为如此,每个递归函数都有其两部分:基线部分和递归条件。 代码示例如下: package cn.recursive.example;
public class RecursiveExample {
    
    
      /**
       * 一个递归方法
       * @param x
       * @return
       */
       static int f(int x) {
           
           if (x == 0) {
               
               return ;
           }
           
           2 * f(x - 1) + x * x;
       }
       
       
      
      
       void main(String[] args) {
           
    
         //调用该方法,当x=2时,输出为6
        System.out.println(RecursiveExample.f(2));
          
    
       }
}代码中的return 0相当于基线条件,而return 2 f(x-1)+x x相当于递归条件。 栈栈是一种数据结构,我们时常用它,而我们自己却不知道。 
 ? 使用栈虽然很方便,但是也是要付出代价: 我的感触: (编辑:锡盟站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! | 




