微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Scala嵌套数组展平

如何展平任何深度的嵌套数组?

例如

val in = Array( 1,Array(2,3),4,Array(Array(5)) )

会被夷为平地

val out = Array(1,2,3,5)

提前致谢.

解决方法

如果你有混合的Int和Array [Int],这不是一个好主意,你可以做类似的事情

in.flatMap{ case i: Int => Array(i); case ai: Array[Int] => ai }

(如果你在数组中添加了其他内容,它将抛出异常).因此,您可以将此作为递归函数的基础:

def flatInt(in: Array[Any]): Array[Int] = in.flatMap{
  case i: Int => Array(i)
  case ai: Array[Int] => ai
  case x: Array[_] => flatInt(x.toArray[Any])
}

如果您不知道嵌套数组中的内容,可以用Any替换上面的Ints,并得到一个平面数组[Any]. (编辑:任何情况都需要最后.)

(注意:这不是尾递归的,所以如果你的数组嵌套得非常深,它会溢出堆栈.)

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐