贴一个在segmentfault的回答, 问题是这样的:
有一个list
, 是有list
嵌套与Str
的混合的list
, 如何能优雅的处理成一个简单的list
?
|
|
有一些要求:
- 实际问题是很大量的数, 如何不增加额外list的情况下处理? (需要内存控制)
- 维度已知, 二维
- 若维度增加, 应该如何处理?
别人的实现办法
有人提供了一个package
可以轻松实现
|
|
递归办法
我自己手搓了一个递归也可以搞定, 支持任意维度, 与之前处理过的一个问题类似: 对任意深度任意形式的list嵌套求平均
|
|
测试结果
|
|
生成器办法
发现递归还是不可避免的增加了额外的list
, 而且数据量大了以后, 内存占用似乎也不占优, 所以是时候搬出generator
大法了.
|
|
果然是一切有for
的地方都可以上yield
的节奏~