leecode如何实现卡牌分组功能
发表于:2025-01-31 作者:千家信息网编辑
千家信息网最后更新 2025年01月31日,这篇文章给大家分享的是有关leecode如何实现卡牌分组功能的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。914. 卡牌分组https://leetcode-cn.com/
千家信息网最后更新 2025年01月31日leecode如何实现卡牌分组功能
这篇文章给大家分享的是有关leecode如何实现卡牌分组功能的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。
914. 卡牌分组
https://leetcode-cn.com/problems/x-of-a-kind-in-a-deck-of-cards/
给定一副牌,每张牌上都写着一个整数。
此时,你需要选定一个数字 X,使我们可以将整副牌按下述规则分成 1 组或更多组:
每组都有 X 张牌。
组内所有的牌上都写着相同的整数。
仅当你可选的 X >= 2 时返回 true。
示例 1:输入:[1,2,3,4,4,3,2,1]输出:true解释:可行的分组是 [1,1],[2,2],[3,3],[4,4]
示例 2:输入:[1,1,1,2,2,2,3,3]输出:false解释:没有满足要求的分组。
示例 3:输入:[1]输出:false解释:没有满足要求的分组。
示例 4:输入:[1,1]输出:true解释:可行的分组是 [1,1]
示例 5:输入:[1,1,2,2,2,2]输出:true解释:可行的分组是 [1,1],[2,2],[2,2]
提示:1 <= deck.length <= 100000 <= deck[i] < 10000
思路:
如果每个元素的次数相等时,满足要求
如果每个元素的次数不相等时,找元素个数的最小公倍数是否存在
class Solution: def hasGroupsSizeX(self, deck: List[int]) -> bool: if deck is None or len(deck) < 2: return False deck_dict = {} # 用来存放元素及其个数 for i in deck: deck_dict[i] = deck_dict[i]+1 if i in deck_dict else 1 count = list(deck_dict.values()) # 每个元素的次数列表 min_count = min(count) # 从中找到最小的元素个数 if len(set(count)) == 1: return True else: for X in range(2, min_count+1): # 从2开始的公约数,不能是以最小元素个数 succes = 1 # 成功的标志 for c in count: if c % X != 0: succes = 0 break if succes == 1: return True return False
感谢各位的阅读!关于"leecode如何实现卡牌分组功能"这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!
分组
元素
示例
解释
输入
输出
个数
可行
最小
更多
次数
功能
内容
整数
篇文章
不错
实用
相同
成功
从中
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
德州服务器管理系统商家
如何查看服务器内存错误
新橙互联网科技有限公司
软件开发及服务发票样板
为什么上传数据库密码不对
数据库技术与应用查题
mycobank数据库
济南软件开发的
数据库用的什么机械硬盘
复旦软件开发工具实践
免费云数据库服务器
Asp绕过安全狗下载数据库
vb数据库html
邯郸软件开发外包
jj怪服务器
带web服务器的wifi模块
香港菠菜服务器
鞍山网络技术有限公司
永彬软件开发有限公司
互联网软件开发流程6
广西科技大学网络安全
软件开发外包一个月3w
数据通信与ip网络技术实验操作
服务器管理器 产品id
全国优抚信息管理系统服务器地址
文明重启带粉丝玩普通服务器
网络安全工作考核指标
网络安全研讨班心得
数据库转义反斜杠n
软件开发平台功能