我有一个列表[0, 3, 2, 1],我想找到差为 1 的 2 个数字的所有可能组合,即|a - b| = 1。所以期望的结果是[(0, 1), (3, 2), (2, 1)]
我知道itertools.combinations并且我知道我可以这样做:
nums = [0, 3, 2, 1]
combs = list(combinations(nums, 2))
adj_combs = [comb for comb in combs if abs(comb[0] - comb[1]) == 1]
但似乎效率很低。有没有更有效的方法来做同样的事情?
莫回无
相关分类