我只是在练习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,ie 100,但不适用于输入2,即55,我清楚地理解,在第二种情况下,10是输出,因为迭代不是递归的。
那么,如何使这个lambda表达式是递归的,以便它也能在第二种情况下工作呢?我可以用这个lambda表达式创建一个方法,每次调用它,直到返回值is< 10为止,但是我在考虑在lambda中是否有任何方法。
谢谢
发布于 2015-10-25 09:59:07
如果您想要一个纯lambda解决方案,您应该忘记让它是递归的,因为绝对没有理由将迭代过程实现为递归:
Stream.iterate(String.valueOf(number),
n -> String.valueOf(n.codePoints().map(Character::getNumericValue).sum()))
.filter(s -> s.length()==1)
.findFirst().ifPresent(System.out::println);演示
发布于 2015-10-25 09:46:03
在Java中使lambda递归并不容易,因为“变量可能未初始化”错误,但这是可以完成的。这是一个链接到描述一种方法的答案。
当应用于您的任务时,可以这样做:
// This comes from the answer linked above
class Recursive<I> {
public I func;
}
public static void main (String[] args) throws java.lang.Exception {
Recursive<Function<Integer,Integer>> sumDigits = new Recursive<>();
sumDigits.func = (Integer number) -> {
int s = Arrays.asList( String.valueOf(number).split("") )
.stream()
.map(Integer::valueOf)
.mapToInt(i->i)
.sum();
return s < 10 ? s : sumDigits.func.apply(s);
};
System.out.println(sumDigits.func.apply(100) == 1);
System.out.println(sumDigits.func.apply(101) == 1);
System.out.println(sumDigits.func.apply(55) == 1);
System.out.println(sumDigits.func.apply(56) == 1);
}我将您的代码包装在{ .}中,并在return行上添加了一个递归调用。
演示。
https://stackoverflow.com/questions/33328025
复制相似问题