31-方法递归调用

2020-10-12  本文已影响0人  c88bc9f9d088

    方法的递归调用指的是一个方法自己调用自己的情况,利用递归调用可以解决一些重复且麻烦的问题。在进行方法递归调用的时候一般需要考虑如下几点问题:

范例:实现一个1~100的累加

//递归方式:
public class JavaDemo {
    public static void main(String [] args){
        System.out.println(sum(100));
    }
    public static int sum(int num){
        if(num == 1){
            return 1;
        }
        return num + sum(num - 1);
    }
}
//传统方式:
public class JavaDemo {
    public static void main(String [] args){
        int sum = 0;
        int x = 1;
        while(x<=100){
            sum += x;
            x++;
        }
        System.out.println(sum);
    }
}

    下面对此代码进行一些简单的分析处理:
· 【第1次执行sum(),主方法执行】return 100 + sum(99);
· 【第2次执行sum(),sum()递归调用】return 99 + sum(98);
· … … … … … …
· 【第99次执行sum(),sum()递归调用】return 2 + sum(1);
· 【第100次执行sum(),sum()递归调用】return 1;
整体形式:return 100 + 99 + 98 + … … .. + 2 + 1;递归操作虽然可以简化的调用,但是在实际开发之中,编写的代码可能会很少出现有递归情况。大部分情况下考虑的都只是一些简单的处理逻辑。递归少去使用还有另外一个原因:如果处理不当则会造成内存有溢出。

范例:计算“1!+2!+3!+4!+5!+… … +90!”
    在进行阶乘计算的时候必须要考虑选择的数据类型,肯定不能够使用int或long,只能够使用double。

public class JavaDemo {
    public static void main(String [] args){
        System.out.println(sum(90));
        System.out.println(fan(90));
    }
    public static double sum(int num){
        if(num == 1) return 1;
        return fan(num) + sum(num - 1);
    }
    public static double fan(int num){
        if(num == 1){
            return 1;
        }
        return num * fan(num - 1);
    }
}

    实际上有一部分的递归都是可以通过循环来完成,但是如果使用递归要比使用循环结构看起来更加清晰一些。

上一篇下一篇

猜你喜欢

热点阅读