博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
递归【应用】
阅读量:2162 次
发布时间:2019-05-01

本文共 884 字,大约阅读时间需要 2 分钟。

  • 递归的介绍

    • 以编程的角度来看,递归指的是方法定义中调用方法本身的现象

    • 把一个复杂的问题层层转化为一个与原问题相似的规模较小的问题来求解

    • 递归策略只需少量的程序就可描述出解题过程所需要的多次重复计算

  • 递归的基本使用

public class DiGuiDemo {    public static void main(String[] args) {        //回顾不死神兔问题,求第20个月兔子的对数        //每个月的兔子对数:1,1,2,3,5,8,...        int[] arr = new int[20];        arr[0] = 1;        arr[1] = 1;        for (int i = 2; i < arr.length; i++) {            arr[i] = arr[i - 1] + arr[i - 2];        }        System.out.println(arr[19]);        System.out.println(f(20));    }    /*        递归解决问题,首先就是要定义一个方法:            定义一个方法f(n):表示第n个月的兔子对数            那么,第n-1个月的兔子对数该如何表示呢?f(n-1)            同理,第n-2个月的兔子对数该如何表示呢?f(n-2)        StackOverflowError:当堆栈溢出发生时抛出一个应用程序递归太深     */    public static int f(int n) {        if(n==1 || n==2) {            return 1;        } else {            return f(n - 1) + f(n - 2);        }    }}

递归的注意事项

  • 递归一定要有出口。否则内存溢出

  • 递归虽然有出口,但是递归的次数也不宜过多。否则内存溢出

转载地址:http://reyzb.baihongyu.com/

你可能感兴趣的文章
6 种用 LSTM 做时间序列预测的模型结构 - Keras 实现
查看>>
走进JavaWeb技术世界1:JavaWeb的由来和基础知识
查看>>
走进JavaWeb技术世界2:JSP与Servlet的曾经与现在
查看>>
走进JavaWeb技术世界3:JDBC的进化与连接池技术
查看>>
走进JavaWeb技术世界4:Servlet 工作原理详解
查看>>
走进JavaWeb技术世界5:初探Tomcat的HTTP请求过程
查看>>
走进JavaWeb技术世界6:Tomcat5总体架构剖析
查看>>
走进JavaWeb技术世界7:Tomcat和其他WEB容器的区别
查看>>
走进JavaWeb技术世界9:Java日志系统的诞生与发展
查看>>
走进JavaWeb技术世界10:从JavaBean讲到Spring
查看>>
走进JavaWeb技术世界11:单元测试框架Junit
查看>>
走进JavaWeb技术世界12:从手动编译打包到项目构建工具Maven
查看>>
走进JavaWeb技术世界13:Hibernate入门经典与注解式开发
查看>>
走进JavaWeb技术世界14:Mybatis入门
查看>>
走进JavaWeb技术世界16:极简配置的SpringBoot
查看>>
初探Java设计模式1:创建型模式(工厂,单例等)
查看>>
初探Java设计模式2:结构型模式(代理模式,适配器模式等)
查看>>
初探Java设计模式3:行为型模式(策略,观察者等)
查看>>
初探Java设计模式4:一文带你掌握JDK中的设计模式
查看>>
初探Java设计模式5:一文了解Spring涉及到的9种设计模式
查看>>