Python 从 n 个数字的列表中生成备选数字列表

Python produce alternative numbers list from a list of n numbers

我有一个包含 n 个数字的列表。我想将它们分组在 g 组中。另外,我想反转每个奇数组中的元素。最后,我会将偶数组和奇数组中的所有元素组合到一个新的子列表中。首先,我给出了我期望的答案以及我哪里出错了:

预期答案:

num = 14
grp = 4
# A list of num natural numbers arranged in group (row) of 4 numbers
lst = 
[0,1,2,3,
4,5,6,7,
8,9,10,11,
12,13]
lst = 
[[0,1,2,3],
[4,5,6,7],
[8,9,10,11],
[12,13]]

# Reverse elements in odd rows
newlst = 
[[0,1,2,3],
[7,6,5,4], # reversed here
[8,9,10,11],
[13,12]]  # reversed here
# combine elements in all sublists by their position
# combine first element in all sublists into a new sublist
sollst = 
[[0,7,8,13],[1,6,9,12],[2,5,10],[3,4,11]]

我的解决方案:

num = 14
grp = 4

#### print
lst= list(range(0,num,1))
newlst= [lst[i:i+grp:1] for i in range(0,num,grp)]
evnlst = newlst[0::2]
oddlst = newlst[1::2]
newoddlst = [oddlst [i][::-1] for i in range(len(oddlst))]
sollst= evnlst + newoddlst 
# This gives [[0, 1, 2, 3], [8, 9, 10, 11], [7, 6, 5, 4], [13, 12]]
from itertools import zip_longest    
print([[x for x in t if x is not None] for t in zip_longest(fevngps)])

当前答案: 我到达了最终答案之前的一步,现在我必须组合不同长度的列表,我 运行 变成了一个错误

TypeError: 'int' object is not subscriptable

一种方法:

from itertools import zip_longest

num = 14
grp = 4

lst = list(range(0, num, 1))
newlst = [lst[i:i + grp:1] for i in range(0, num, grp)]

# build new list where the sub-list are reversed if in odd indices
revlst = [lst[::-1] if i % 2 == 1 else lst for i, lst in enumerate(newlst)]

# zip using zip_longest and filter out the None values (the default fill value of zip_longest)
result = [[v for v in vs if v is not None] for vs in zip_longest(*revlst)]
print(result)

输出

[[0, 7, 8, 13], [1, 6, 9, 12], [2, 5, 10], [3, 4, 11]]