In[7]: text=[u'[', u'Paradise', u'Lost', u'by', u'John', u'Milton', u'1667', u']', u'Book', u'I', u'Of', u'Man', u"'", u's', u'first', u'disobedience', u',', u'and', u'the', u'fruit']
In[8]: longest = ''
In[9]: for word in text:
... if len(word) > len(longest):
... longest = word
...
In[10]: longest
Out[10]: u'disobedience'
In[11]: maxlen = max(len(word) for word in text)
In[12]: [word for word in text if len(word) == maxlen]
Out[12]: [u'disobedience']
第一个解决方案找到的是第一个长度最长的词,而第二种方案找到的是所有最长的词(通常是我们想要的)。
这两种方案之间存在理论效率的差异,主要是在内存中读取数据,一旦数据准备好,第二阶段处理数据可以瞬间高效地完成。
第二种方案的代码简洁清晰,更易维护。