内容简介:前面我们get到了一个技能,生成器。那么如果我们想依次输出一个数组,但是数组中又嵌套数组,又嵌套数组...嵌套未知层,那么如何实现?如果使用for可能就有点不方便了,这时我们需要递归。我们可以这样做,
前面我们get到了一个技能,生成器。
那么如果我们想依次输出一个数组,但是数组中又嵌套数组,又嵌套数组...嵌套未知层,那么如何实现?如果使用for可能就有点不方便了,这时我们需要递归。
我们可以这样做,
def myFlatten(seq): try: for list in seq: for item in myFlatten(list): yield item except Exception: yield seq
测试我们的代码
seque=[[1,[2,[3]]],[4,[5,[6,[7,[8]]]]],[9,10],[11]] for item in myFlatten(seque): print(item)
输出
print(list(myFlatten(seque)))
输出
[1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11]
对于上述实现方式,我们发现并不完善,如果数组是字符串那就可能引发typeError异常。于是我们增加一个检查的逻辑。
def myFlattenAdvance(seq): try: try: seq+'' except TypeError: pass else:raise TypeError for list in seq: for item in myFlattenAdvance(list): yield item except Exception: yield seq
发现类型错误,则在异常中处理,本段代码中,我们不做异常处理。
测试调用如下,
strSeq=['魔礼青',['魔礼海',['魔礼红','魔礼寿']]] for item in myFlattenAdvance(strSeq): print(item)
输出
魔礼青 魔礼海 魔礼红 魔礼寿
print(list(myFlattenAdvance(strSeq)))
输出
['魔礼青', '魔礼海', '魔礼红', '魔礼寿']
这样我们可以递归字符串类型的数组了。
工程文件下载: https://download.csdn.net/download/yysyangyangyangshan/10821963
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
数据结构及应用算法教程
2011-5 / 45.00元
《数据结构及应用算法教程(修订版)》从数据类型的角度,分别讨论了四大类型的数据结构的逻辑特性、存储表示及其应用。此外,还专辟一章,以若干实例阐述以抽象数据类型为中心的程序设计方法。书中每一章后都配有适量的习题,以供读者复习提高之用。第1~9章还专门设有“解题指导与示例”一节内容,不仅给出答案,对大部分题目提供了详尽的解答注释;其中的一些算法题还给出了多种解法。书中主要算法和最后一章的实例中的全部程......一起来看看 《数据结构及应用算法教程》 这本书的介绍吧!