我只是练习lamdas java 8.我的问题如下
将一个整数中的所有数字求和,直到小于10(表示剩下一位数)并检查其是否为1
样本输入1
100
样本输出1
1 // true because its one
样本输入2
55
样本输出2
1 ie 5+5 = 10 then 1+0 = 1 so true
我写了一个代码
System.out.println(Arrays.asList( String.valueOf(number).split("") ).stream()
.map(Integer::valueOf)
.mapToInt(i->i)
.sum() == 1);
它适用于输入1即100但不适用于输入2,即55,我清楚地理解,在第二种情况下10是输出,因为迭代不是递归的.
那么如何才能使这个lambdas表达式递归,以便它也可以在第二种情况下工作呢?我可以使用该lambda表达式创建一个方法,并每次调用它,直到返回值为