加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Python > 正文

如何将子列表拆分为子列表k次? (Python)

发布时间:2020-12-16 22:59:47 所属栏目:Python 来源:网络整理
导读:我知道我可以使用以下方法将列表拆分为相同大小的子列表: segment = len(list)//ksub_lists = [list[i:i+segment] for i in range(0,len(list),segment)] 但是,我不确定如何将长度为k ^ m的列表拆分为子列表,然后是其他子列表,直到每个子列表的长度为1. 例
我知道我可以使用以下方法将列表拆分为相同大小的子列表:
segment = len(list)//k
sub_lists = [list[i:i+segment] for i in range(0,len(list),segment)]

但是,我不确定如何将长度为k ^ m的列表拆分为子列表,然后是其他子列表,直到每个子列表的长度为1.

例如:

k = 2
list = [1,2,3,4,5,6,7,8]
list = [[1,4],[5,8]]
list = [[[1,2],[3,4]],[[5,6],[7,8]]]
list = [[[[1],[2]],[[3],[4]]],[[[5],[6]],[[7],[8]]]]

每当我试图循环这个时,我就会被打结,是否有捷径?

解决方法

这基本上就是你的代码:
def split_list(input_list,segments):
    if len(input_list) == 1:
        return input_list
    segment_length = len(input_list) // segments
    return [split_list(input_list[i:i+segment_length],segments) 
            for i in range(0,len(input_list),segment_length)]

>>> split_list([1,8],2)
[[[[1],[8]]]]

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读