LeetCode-846 一手顺子
2024-10-20 20:33:06
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/hand-of-straights
题目描述
Alice 手中有一把牌,她想要重新排列这些牌,分成若干组,使每一组的牌数都是 groupSize ,并且由 groupSize 张连续的牌组成。
给你一个整数数组 hand 其中 hand[i] 是写在第 i 张牌,和一个整数 groupSize 。如果她可能重新排列这些牌,返回 true ;否则,返回 false 。
示例 1:
输入:hand = [1,2,3,6,2,3,4,7,8], groupSize = 3
输出:true
解释:Alice 手中的牌可以被重新排列为 [1,2,3],[2,3,4],[6,7,8]。
示例 2:
输入:hand = [1,2,3,4,5], groupSize = 4
输出:false
解释:Alice 手中的牌无法被重新排列成几个大小为 4 的组。
提示:
1 <= hand.length <= 104
0 <= hand[i] <= 109
1 <= groupSize <= hand.length
解题思路
使用贪心算法的思路,从小牌开始组顺子,如果小牌都无法组顺子,那么必定这副牌没有办法组成顺子,一直到所有的牌组成顺子为止。
使用桶排序统计这副牌的不同牌面的个数。
从小开始遍历,在小牌x数量不为0情况下,寻找区间[x + 1, x + groupSize) 的牌面个数是否小于x的数量,如果是,那么x无法组成规定的顺子,返回false,如果不是,在区间中减去x的数量同时将x数量置为0。
当遍历完毕,代表所有牌都组成了顺子,返回true。
代码展示
class Solution {
public:
bool isNStraightHand(vector<int>& hand, int groupSize) {
map<int, int> mapiiBucket;
for(auto iter : hand)
{
mapiiBucket[iter]++;
}
for(auto iter: mapiiBucket)
{
if(iter.second > 0)
{
int iX = iter.second;
mapiiBucket[iter.first] = 0;
for(int i = 1; i < groupSize; i++)
{
if(mapiiBucket[iter.first + i] < iX)
{
return false;
}
mapiiBucket[iter.first + i] -= iX;
}
}
}
return true;
}
};
运行结果
最新文章
- c# winform DirectX播放器 可以任意设置宽高比 屏幕拉伸
- linux下网卡启动、配置
- 解决PHP生成校验码时“图像因其本身有错无法显示”的错误
- linux 的 scp 命令 可以 在 linux 之间复制 文件 和 目录
- OracleApps Dropship 流程
- mysql的replication(主从同步)总结
- 【hoj】1604 cable master
- 伪元素::selection(怎么修改网页中被选中文本的样式)
- python学习笔记之11:图像用户界面
- 向EXECL文件中导入数据的同时插入图片
- 封装一个通过class获取元素的方法--我的JS原生库(1)
- 【NOIP2012】开车旅行(倍增)
- lvds接口介绍
- abp框架下,donet core配置swagger
- TRIO-basic变量的状态位
- webpack 学习资料
- 03_java基础(六)之CRUD实现
- Android笔记之属性动画
- 【黑金原创教程】【FPGA那些事儿-驱动篇I 】实验十三:串口模块② &mdash; 接收
- Kotlin——初级篇(一):最详细的环境搭建
热门文章
- 论文解读(PCL)《Probabilistic Contrastive Learning for Domain Adaptation》
- C# 11新特性之file关键字
- 动态更改Spring定时任务Cron表达式的优雅方案
- 认识一下 Mobx
- Vue前后端分离实现登录的一个简单demo
- [python] 基于chardet识别字符编码
- C#开发的插件程序 - 开源研究系列文章
- 【集成开发环境 (IDE)】Dev-Cpp下载与安装 [ 图文教程 ]
- Flutter异常监控 - 伍 | 关于异常监控框架设计的思考
- odoo资料