Java - 数字的递归总和及其工作原理

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Java - 数字的递归总和及其工作原理相关的知识,希望对你有一定的参考价值。

我试图写一个递归函数,当我用数字5调用时,函数将计算所有数字的总和为5。 1 + 2 + 3 + 4 + 5 = 15

当前代码总是返回0,每次n的数量怎么样?

public class t {
public static void main(String[] args) {

    System.out.println(num(5));
}

public static int num(int n) {

    int sum = 0;
    sum += n;
    if (n == 0)
        return sum;

    return num(n - 1);

}

}

谢谢。

答案

而不是将总和设置为0,你可以 - 做这个:

public int sumUp(int n){

    if (n==1)
        return 1;
    else
       return sumUp(n-1)+n;
}
另一答案

问题是你总和设置为0。

public static void main(String[] args) {
    System.out.println(num(5, 0));
}

public static int num(int n, int sum) {
    if (n == 0) {
        return sum;
    }

    sum += n;
    return num(n - 1, sum);

}
另一答案
public static int withRecursion(List<Integer> list) {

    int size = list.size();
    int a=0;

    if(list.isEmpty() == true) {
        return 0;

    }else {
        a = a + list.get(0) + withRecursion(list.subList(1, size)); 
        return  a;      
    }   

}

以上是关于Java - 数字的递归总和及其工作原理的主要内容,如果未能解决你的问题,请参考以下文章

递归:数字的总和,直到剩下一位数

关于 Java 新手的递归

没有正确数字的递归数字总和

无法在递归java函数中计算总和

C指针原理(27)-编译基本原理-语法树及其实现7

给定二进制字符串中不同数字的数量及其总和