【贪心】【哈希表】个人练习-Leetcode-846. Hand of Straights

题目链接:https://leetcode.cn/problems/hand-of-straights/

题目大意:给出一数列,求是否能刚好将它们分成若干组,每组的元素数量为groupSize,并且元素连续。

思路:因为题目的限制很死,如果能够分那么分的结果一定是确定的。那么就可以贪心做。

先排序,并记录每种元素出现的次数,用哈希表cnt来记。然后从小到大遍历,每轮从【残存次数大于0的最小的数】开始(可以用一个vector来存这些数字,每个只存一次,起到一个set一样的效果),然后往后groupSize的数的残存次数都-1。如果中间任何一个地方出问题都会不合法,直接返回false

做完一下就通过了,但时间不是很理想。于是改了一下,每轮找【残存次数大于0的最小的数】的下标可以复用,直接从上一轮的继承就行了。结果果然快了不少。

完整代码

cpp 复制代码
class Solution {
public:
    bool isNStraightHand(vector<int>& hand, int groupSize) {
        int n = hand.size();
        if (n % groupSize)
            return false;
        sort(hand.begin(), hand.end());
        vector<int> nums;
        
        unordered_map<int, int> cnt;
        for (auto x : hand) {
            cnt[x]++;
            if (nums.size() == 0 || nums.back() != x)
                nums.emplace_back(x);
        }

        int lpn = n / groupSize;
        int idx = 0;
        for (int k = 0; k < lpn; k++) {
            while (cnt[nums[idx]] == 0)
                idx++;
            int num = nums[idx];
            if (cnt[num]) {
                cnt[num]--;
                for (int j = num+1; j < num + groupSize; j++) {
                    if (cnt[j] == 0)
                        return false;
                    else 
                        cnt[j]--;     
                }
            }
        }
        return true;
    }
};
相关推荐
XiYang-DING2 小时前
【LeetCode】Hash | 136.只出现一次的数字
算法·leetcode·哈希算法
Tairitsu_H3 小时前
C语言:排序(一)
c语言·数据结构·排序
嘻嘻哈哈樱桃4 小时前
俄罗斯套娃信封问题力扣--354
算法·leetcode·职场和发展
田梓燊4 小时前
2026/4/12 leetcode 1320
算法·leetcode·职场和发展
j_xxx404_4 小时前
力扣题型--链表(两数相加|两两交换链表中的节点|重排链表)
数据结构·c++·算法·leetcode·蓝桥杯·排序算法
_日拱一卒5 小时前
LeetCode:240搜索二维矩阵Ⅱ
数据结构·线性代数·leetcode·矩阵
WolfGang0073215 小时前
代码随想录算法训练营 Day33 | 动态规划 part06
算法·leetcode·动态规划
米粒16 小时前
力扣算法刷题 Day 41(买卖股票)
算法·leetcode·职场和发展
计算机安禾6 小时前
【数据结构与算法】第44篇:堆(Heap)的实现
c语言·开发语言·数据结构·c++·算法·排序算法·图论
汀、人工智能6 小时前
[特殊字符] 第91课:课程表
数据结构·算法·数据库架构·图论·bfs·课程表