我有一个列表,其中每个元素都是一个字符:
ngrams = [['a', 'b', 'c', 'a', 'b', 'c', 'a', 'b', 'c'],
['a', 'a', 'a', 'b', 'b', 'b', 'c', 'c', 'c']]由此,我想用内容['aa','ab','ac','ba','bb','bc','ca','cb','cc']生成一个新的单一列表。每个列表的各个元素相互附加,但按列表的顺序相反。我想出了这个(其中的np = 2):
for cnt in range(np-2,-1,-1):
thisngrams[-1] = [a+b for (a,b) in zip(thisngrams[-1],thisngrams[cnt])] 我的解决方案需要处理高于2的np,我希望这是O(np),这并不坏。有人能建议一种更有效率和更有效的节能型方法来做我想做的事情吗(或者这是一种很好的琵琶方法)?
发布于 2017-06-19 14:13:06
你可以试试这个:
ngrams = [['a', 'b', 'c', 'a', 'b', 'c', 'a', 'b', 'c'],
['a', 'a', 'a', 'b', 'b', 'b', 'c', 'c', 'c']]
new = map(''.join, zip(*ngrams))输出:
['aa', 'ba', 'ca', 'ab', 'bb', 'cb', 'ac', 'bc', 'cc']有两个以上的要素:
n = [["a", "b", "c"], ["a", "c", "d"], ["e", "f", "g"]]
new = map(''.join, zip(* reversed(ngrams)))
#in Python3
#new = list(map(''.join, zip(* reversed(ngrams))))输出:
['eaa', 'fcb', 'gdc']https://stackoverflow.com/questions/44632877
复制相似问题