栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

用于解决斐波那契的Java 8 Lambda表达式(非递归方式)

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

用于解决斐波那契的Java 8 Lambda表达式(非递归方式)

最简单的解决方案是使用

Pair
s 流:

Stream.iterate(new long[]{ 1, 1 }, p->new long[]{ p[1], p[0]+p[1] })      .limit(92).forEach(p->System.out.println(p[0]));

由于缺少标准对类型,因此使用了两个元素的数组。此外,

.limit(92)
由于无法使用
long
值来评估更多元素,因此我使用。但是很容易适应
BigInteger

Stream.iterate(new BigInteger[]{ BigInteger.ONE, BigInteger.ONE },    p->new BigInteger[]{ p[1], p[0].add(p[1]) })      .forEach(p->System.out.println(p[0]));

它将一直运行,直到您没有足够的内存来表示下一个值。

顺便说一句,要从流中获取第n个元素:

Stream.iterate(new long[]{1, 1}, p -> new long[]{p[1], p[0] + p[1]})    .limit(91).skip(90).findFirst().get()[1];


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/496120.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号