Scala中运行总和的流

这是我上一个问题的后续行动.
给定函数add_stream(s1:Stream [Int],s2:Stream [Int]):Stream [Int]
我想编写running_sums(s:Stream [Int]):Stream [Int],它返回一个新流:s1,s1 s2,s1 s2 s3,…

我可以想到以下实现,但如果s为空则它不起作用

def running_sums(s:Stream[Int]):Stream[Int] =
  Stream.cons(s.head,add_streams(s.tail,running_sums(s)))

我可以修复如下:

def running_sums(s:Stream[Int]):Stream[Int] =
  if (s.isEmpty) empty
    else Stream.cons(s.head,running_sums(s)))

然而它看起来并不优雅.

你将如何实现running_sums?

解决方法

一个像这样的东西的库调用,称为scanLeft

s.scanLeft(0)(_+_).tail

相关文章

共收录Twitter的14款开源软件,第1页Twitter的Emoji表情 Tw...
Java和Scala中关于==的区别Java:==比较两个变量本身的值,即...
本篇内容主要讲解“Scala怎么使用”,感兴趣的朋友不妨来看看...
这篇文章主要介绍“Scala是一种什么语言”,在日常操作中,相...
这篇文章主要介绍“Scala Trait怎么使用”,在日常操作中,相...
这篇文章主要介绍“Scala类型检查与模式匹配怎么使用”,在日...