首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在scala中创建提供f(n)=f(n-2)+f(n-3)的流

如何在scala中创建提供f(n)=f(n-2)+f(n-3)的流
EN

Stack Overflow用户
提问于 2015-07-03 18:35:24
回答 2查看 52关注 0票数 3

我试过这个:

代码语言:javascript
复制
val s1:Stream[Int]=1 #:: 0 #:: 1 #:: 1 #:: (s1.tail.tail.tail,s1.tail.tail).zipped.map{(c,d) => c + d}.toStream

代码语言:javascript
复制
s1(5)

引发堆栈溢出...

我用两个参数成功地写出了正确的定义:

代码语言:javascript
复制
val s2:Stream[Int]=1 #:: 0 #:: 1 #:: 1 #:: (s2.tail.tail.tail.zip(s2.tail.tail)).map{n=> n._1+n._2}

但是我将来会想要添加2个以上的列表,这就是为什么我希望能够使用"zipped“而不是"zip”。

谢谢

EN

回答 2

Stack Overflow用户

发布于 2015-07-03 18:45:34

Stream.iterate((1, 0, 1))({case (a, b, c) => (b, c, a + b)}).map(_._3)呢?

票数 1
EN

Stack Overflow用户

发布于 2015-07-03 18:52:52

看起来这段代码正确地生成了你的序列:

代码语言:javascript
复制
val s:Stream[Int]=1 #:: 0 #:: 1 #:: 1 #:: (s.tail zip s.tail.tail).map {t => t._1 + t._2}

例如:

代码语言:javascript
复制
s(7) = 3
s(8) = 4
s(10) = 7
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/31204708

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档