前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Python|力扣166周第二题用户分组题

Python|力扣166周第二题用户分组题

作者头像
算法与编程之美
发布2020-02-13 17:45:19
4530
发布2020-02-13 17:45:19
举报

本文首发于微信公众号:"算法与编程之美",欢迎关注,及时了解更多此系列文章。

问题描述

有 n 位用户参加活动,他们的 ID 从 0 到 n - 1,每位用户都恰好 属于某一用户组。给你一个长度为 n 的数组 groupSizes,其中包含每位用户所处的用户组的大小,请你返回用户分组情况(存在的用户组以及每个组中用户的 ID)。 你可以任何顺序返回解决方案,ID 的顺序也不受限制。此外,题目给出的数据保证至少存在一种解决方案。

示例 1:

输入:groupSizes = [3,3,3,3,3,1,3]

输出:[[5],[0,1,2],[3,4,6]]

解释:

其他可能的解决方案有 [[2,1,6],[5],[0,4,3]] 和[[5],[0,6,2],[4,3,1]]。

示例 2:

输入:groupSizes = [2,1,3,3,3,2]

输出:[[1],[0,5],[2,3,4]]

提示:groupSizes.length == n

1 <= n <= 500

1 <= groupSizes[i] <= n

解决方案

观察该题我们可得:输出的是groupSizes的值所对应改值的长度的列表;所以,该题我想到的解决方案是新建两个列表,将满足条件的数通过列表切割将其放入其中的一个新建列表之中,然后再利用切割的方式将新建列表中的代码取出来放入另一个新建列表之中,不过要注意一些其中的条件。

代码示例:

代码语言:javascript
复制
groupSizes=input()

groupSizes=list(eval(groupSizes))

n=[]

for i in range(len(groupSizes)):

    if groupSizes[i] not in groupSizes[:i]:

        s=[]

        for k in range(i,len(groupSizes)):

            if groupSizes[i]==groupSizes[k]:

                s.append(k)

                if len(s)%groupSizes[i]==0:

                    n.append(s[-groupSizes[i]:])

                continue

            if groupSizes[i]==1 and i==k:

                s.append(i)

                n.append(s[-1:])

                break 

print(n)

该代码中的两个列表分别为s[]和n[],s[]就是用来装入满足条件的元素,而n[]列表则是用来将满足条件的元素以列表的形式装入,最后输出正确的格式。

结语

对于该题的上手有一些难度,不过这是一个提升的好方法。该题我采用了列表的方法来解决,可能会有些繁琐,但对于更好的掌握列表来解决问题会更有帮助。

参考文献

力扣(LeetCode)

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2020-01-11,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 算法与编程之美 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
访问管理
访问管理(Cloud Access Management,CAM)可以帮助您安全、便捷地管理对腾讯云服务和资源的访问。您可以使用CAM创建子用户、用户组和角色,并通过策略控制其访问范围。CAM支持用户和角色SSO能力,您可以根据具体管理场景针对性设置企业内用户和腾讯云的互通能力。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档