来源:力扣(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;
}
};

运行结果

最新文章

  1. c# winform DirectX播放器 可以任意设置宽高比 屏幕拉伸
  2. linux下网卡启动、配置
  3. 解决PHP生成校验码时“图像因其本身有错无法显示”的错误
  4. linux 的 scp 命令 可以 在 linux 之间复制 文件 和 目录
  5. OracleApps Dropship 流程
  6. mysql的replication(主从同步)总结
  7. 【hoj】1604 cable master
  8. 伪元素::selection(怎么修改网页中被选中文本的样式)
  9. python学习笔记之11:图像用户界面
  10. 向EXECL文件中导入数据的同时插入图片
  11. 封装一个通过class获取元素的方法--我的JS原生库(1)
  12. 【NOIP2012】开车旅行(倍增)
  13. lvds接口介绍
  14. abp框架下,donet core配置swagger
  15. TRIO-basic变量的状态位
  16. webpack 学习资料
  17. 03_java基础(六)之CRUD实现
  18. Android笔记之属性动画
  19. 【黑金原创教程】【FPGA那些事儿-驱动篇I 】实验十三:串口模块② &mdash; 接收
  20. Kotlin——初级篇(一):最详细的环境搭建

热门文章

  1. 论文解读(PCL)《Probabilistic Contrastive Learning for Domain Adaptation》
  2. C# 11新特性之file关键字
  3. 动态更改Spring定时任务Cron表达式的优雅方案
  4. 认识一下 Mobx
  5. Vue前后端分离实现登录的一个简单demo
  6. [python] 基于chardet识别字符编码
  7. C#开发的插件程序 - 开源研究系列文章
  8. 【集成开发环境 (IDE)】Dev-Cpp下载与安装 [ 图文教程 ]
  9. Flutter异常监控 - 伍 | 关于异常监控框架设计的思考
  10. odoo资料