Enable Javascript in your browser and then refresh this page, for a much enhanced experience.
recursive generator solution in Clear category for Flatten a List by juestr
def flat_list(array):
def f(l):
for x in l:
if isinstance(x, list):
yield from f(x)
else:
yield x
return list(f(array))
if __name__ == '__main__':
assert flat_list([1, 2, 3]) == [1, 2, 3], "First"
assert flat_list([1, [2, 2, 2], 4]) == [1, 2, 2, 2, 4], "Second"
assert flat_list([[[2]], [4, [5, 6, [6], 6, 6, 6], 7]]) == [2, 4, 5, 6, 6, 6, 6, 6, 7], "Third"
assert flat_list([-1, [1, [-2], 1], -1]) == [-1, 1, -2, 1, -1], "Four"
print('Done! Check it')
April 10, 2019
Comments: