如何使用递归及注意事项

简介: 如何使用递归及注意事项

递归的介绍:

  • 什么是递归?
    解决具有既定规律的问题时,在方法内部再次调用自身方法的一种编程方式。
  • 何时使用递归?
    当需要解决的问题可以拆分成若干个小问题,大小的问题解决方式相同,方法中自己调用自己。
  • 如何正确使用递归?
    设置有效的出口条件,可以让调用链上的每个方法都可以正确返回,避免无穷递归。

下面写一个递归例子:计算10的阶乘:

public class Test1 {
    public static void main(String[] args) {
        // 传入参数
        int result =factorial(5);
        // 输出结果
        System.out.println(result); // 120
    }
    /**
     *  计算阶乘的方法
     */
    public static int factorial(int num) {
        // 设置出口
        if(num==1) {
            return 1;
        }
        // 自己调用自己
        return num*factorial(num-1);
    }
}


目录
相关文章
|
Python
python之for循环的定义,使用方法及其注意事项
python之for循环的定义,使用方法及其注意事项
160 0
数组的解释及使用方法
数组的解释及使用方法
87 0
|
人工智能 编译器 C语言
如何使用函数及函数的注意事项
目录 什么是函数? 如何调用函数? 函数的先后关系? 函数的变量空间? 什么是函数? 首先我们来说一说函数的作用,就是一块简单的代码接受零个或多个参数,做一件事情,并返回零个或一个值 void sum(int a,int b) { int i; int sum=0; for(i=a:i<=b;i++) { sum+=i; } printf("%d到%d的和是%d\n",a,b,sum); } 现在我们就写出了一个简单的求和函数和数学中的y=f(x)很像 函数名 sum 返回类型 void 参数表 int a,int b 函数体 大括号里的所有东西 函数头 大括号前
|
编译器 Scala 开发者
函数使用注意事项和细节2|学习笔记
快速学习函数使用注意事项和细节2。
|
自然语言处理
自己写代码解析工具的注意事项
自己写代码解析工具的注意事项
83 0
指针的基本用法和注意事项
指针的基本用法的详细说明
146 0
指针的基本用法和注意事项
|
算法 Scala 开发者
使用递归的注意事项和陷阱 | 学习笔记
快速学习使用递归的注意事项和陷阱
|
Java 编译器 Scala
函数使用注意事项和细节3|学习笔记
快速学习函数使用注意事项和细节3。
|
Java 编译器 Scala
函数使用注意事项和细节1|学习笔记
快速学习函数使用注意事项和细节1。
|
Java 数据安全/隐私保护 开发者
函数的注意事项| 学习笔记
快速学习函数的注意事项