我想使用lambda表达式而不是for循环生成数字列表.
所以让我们想要生成一个100以下的所有三角形数字的列表.三角数字是以下公式的数字:(n * n n)/ 2
这样做最好的方法是什么?
目前我有这个:
Stream.iterate(1,n -> n + 1).limit(100) .map(n -> (n * n + n) / 2) .filter(a -> a < 100) .map(a -> a + "") .collect(Collectors.joining(",","Numbers: ","."));
但这似乎不必要地过度的计算量.我迭代n超过1到100(因为假设我不知道n的最大值是多少),那么我映射该列表的三角数字函数,然后我检查哪些数字在100以下是否有更有效的方式在这样做?
另外:我可以使用Stream的iterate函数生成三角形数字,而不是使用iterate,limit,然后映射?
编辑:
所以这里的要点是:一旦三角形数字之一超过100,一个数字的计算如何停止?
通常我会这样写:
ArrayList<Integer> triangles = new ArrayList<>(); for (int n=1;true;n++) { int num = (n*n+n)/2; if (num>100) break; triangles.add(num); }
一旦三角形数字超过100,那就停止,这是非常有效的;如何在lambda表达式中保留这个效率?