将列表分成 N 个近似相等的部分
将列表分成相等的部分是一个常见的编程问题。一个特殊的挑战是当列表长度不能被所需的部分数量整除时实现均匀分割。
例如,考虑将 7 个元素的列表分成两个相等的部分。理想情况下,每个部分应分别具有 3 个和 4 个元素。
提供的代码 chunks() 将列表划分为大小相等的元素块,但这可能不会导致甚至分裂。或者,转置块可以实现均匀分割,但会破坏元素排序。
更有效的方法是使用列表生成器,如改进的代码所示:
def split(a, n): k, m = divmod(len(a), n) return (a[i*k+min(i, m):(i+1)*k+min(i+1, m)] for i in range(n))
此代码计算理想的块大小 k 和剩余元素 m。然后,它生成一个生成器,该生成器迭代列表并创建所需大小的部分。
例如:
>>> list(split(range(11), 3)) [[0, 1, 2, 3], [4, 5, 6, 7], [8, 9, 10]]
此解决方案提供了一种将列表拆分为大致相等部分的有效方法,保留元素顺序。
以上是如何将列表分成大致相等的部分?的详细内容。更多信息请关注PHP中文网其他相关文章!