5.14 力扣每日一题 贪心

2244. 完成所有任务需要的最少轮数

cpp 复制代码
class Solution {
public:
    int minimumRounds(vector<int>& tasks) {
        int n=tasks.size(),sum=0;
        sort(tasks.begin(),tasks.end()); //排序就不用哈希表
        int a;
        for(int i=0;i<n;){
            int ct=0;
            a=tasks[i];
            while(i<n&&tasks[i]==a){
                i++;ct++;
            }
            if(ct==1)return -1;
            switch(ct%3){
                case 0:sum+=ct/3;break;
                case 1:sum+=ct/3+1;break;
                case 2:sum+=ct/3+1;break;
            }
        }
        return sum;
    }
};
相关推荐
richard_yuu6 分钟前
数据结构|二叉树高阶进阶-经典算法
数据结构·c++·算法
不知名的忻14 分钟前
Dijkstra算法(朴素版&堆优化版)
java·数据结构·算法··dijkstra算法
星星码️27 分钟前
LeetCode刷题简单篇之反转字母
c++·算法·leetcode
naturerun1 小时前
螺旋形遍历奇数阶矩阵
c++·算法·矩阵
wuweijianlove1 小时前
算法复杂度的实验估算与误差分布建模的技术7
算法
佳xuan2 小时前
简而言之c++
c++·算法
变量未定义~2 小时前
星际争霸、宝石塔的亮度差异、寻找食物储量
算法
YL200404262 小时前
027合并两个有序链表
java·数据结构·算法·链表
MATLAB代码顾问3 小时前
【智能优化】无穷优化算法(INFO)原理与Python实现
开发语言·python·算法
炽烈小老头3 小时前
【每天学习一点算法 2026/05/10】合并K个排序链表
学习·算法·链表