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 - 数字的递归总和及其工作原理的主要内容,如果未能解决你的问题,请参考以下文章