为了账号安全,请及时绑定邮箱和手机立即绑定

获取列表中所有可能相差 1 的数字对

获取列表中所有可能相差 1 的数字对

繁星coding 2023-10-06 18:40:39
我有一个列表[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]但似乎效率很低。有没有更有效的方法来做同样的事情?
查看完整描述

1 回答

?
莫回无

TA贡献1865条经验 获得超7个赞

既然你说顺序并不重要,那么你可以通过先对数字进行排序来大大简化问题。


>>> nums = [0, 3, 2, 1]

>>> sorted_nums = sorted(nums)

>>> adj_combs = [(a,b) for a,b in zip(sorted_nums,sorted_nums[1:]) if abs(a-b) == 1]

>>> adj_combs

[(0, 1), (1, 2), (2, 3)]


查看完整回答
反对 回复 2023-10-06
  • 1 回答
  • 0 关注
  • 84 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信