Java递归调用_递归算法1加到100

Java递归调用_递归算法1加到100递归用于解决什么样的问题?1)各种数学问题如:8皇后问题,汉诺塔,阶乘问题,迷宫问题,球和篮子的问题(google编程大赛)2)各种算法中也会使用到递归,比如快排,归并排序,二分查找,分治算法等.3)将用栈解决的问题–>递归代码比较简洁简单的说:递归就是方法自己调用自己,每次调用时传入不同的变量.递归有助于编程者解决复杂的问题,同时可以让代码变得简洁。递归需要遵守的重要规则:1…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

递归用于解决什么样的问题?

        1)各种数学问题如: 8皇后问题,汉诺塔,阶乘问题,迷宫问题,球和篮子的问题 (google编程大赛)

        2)各种算法中也会使用到递归,比如快排,归并排序,二分查找,分治算法等.

        3)将用栈解决的问题 –> 递归代码比较简洁


简单的说: 

        递归就是方法自己调用自己, 每次调用时传入不同的变量. 递归有助于编程者解决复杂的问题, 同时可以让代码变得简洁。


递归需要遵守的重要规则:

        1) 执行一个方法时,就创建一个新的受保护的独立空间(栈空间)

        2) 方法的局部变量是独立的,不会相互影响,比如n变量

        3) 如果方法中使用的是引用类型变量(比如数组),就会共享该引用类型的数据.

        4) 递归必须向退出递归的条件逼近,否则就是无限递归,出现StackOverflowError,死龟了:)

        5) 当一个方法执行完毕,或者遇到return,就会返回,遵守谁调用,就将结果返回给谁,同时当方法执行完毕或者返回时,该方法也就执行完毕。返回给谁,同时当方法执行完毕或者返回时,该方法也就执行完毕。


列举两个小案例, 回顾一下递归调用机制
1) 打印问题

    public static void main(String[] args) {
        test(4);
    }
    public static void test(int n){
        if (n>1){
            test(n - 2);
        }
        System.out.println("n = " + n);
    }

输出:
        n = 2
        n = 3
        n = 4 

2) 阶乘问题

    public static void main(String[] args) {
        System.out.println(factorial(5));
    }
    public static int factorial(int n){
        if (n==1){
            return 1;
        }else {
            return factorial(n-1)*n;
        }
    }

输出: 120

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/193119.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 电脑定时开机方法「建议收藏」

    电脑定时开机方法「建议收藏」让电脑自动开机方法一:BIOS首先开机后按住Delete键,就是平常常用的删除按键(见图1),然后就会进入到BIOS界面。虽然是一个满眼E文的蓝色世界,但不要害怕,没有问题的。图2在BIOS设置主

    2022年8月4日
    3
  • Crsctl_fsck命令

    Crsctl_fsck命令一.crsctl1.crsctl语法1)语法$crsctl<command><object>[<options>]2)命令add|check|config|create|debug|delete|disable|discover|enable|eval|export|get|getperm|lsmodules|modify|pin|query|release|relocate|replace|request|set|setperm|start|stat.

    2022年9月11日
    0
  • CentOS 6安装gcc 4.7[通俗易懂]

    CentOS 6安装gcc 4.7

    2022年2月22日
    42
  • postman中文版界面_英雄连2菜单汉化界面

    postman中文版界面_英雄连2菜单汉化界面参考:大佬的Gitee地址:gitee地址

    2022年9月29日
    0
  • Let’s Encrypt 申请HTTPS证书流程「建议收藏」

    Let’s Encrypt 申请HTTPS证书流程「建议收藏」准备工作:域名可供解析的服务器(或使用ngrok将需要生成证书的域名映射到具体的http服务器地址)申请官网地址:Let’sEncrypt、Certbot流程打开Certbot网址,选择使用服务器与操作系统,如下:使用如上命令在对应服务器安装好certbot后,使用:sudocertbotcertonly命令安装,certbot(实际上是certbot-au…

    2022年9月1日
    0
  • 单片机引脚控制继电器最简单的电路方式

    单片机引脚控制继电器最简单的电路方式首先要明确一点:单片机不能直接控制继电器,不管是3v的继电器还是5v的继电器。原因:比如51单片机和msp430单片机,引脚不能直接接继电器。虽然引脚的电压足够,但是由于电流不够,所以本应该闭合的线圈不会闭合。需要增加一个三极管来放大电流。说是放大电流,其实本质上是把引脚当成一个开关来控制真正3.3v电压的开合。下图是在实践中自己设计的可以正常工作的继电器模块。

    2022年6月24日
    34

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号