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;
    }
};
相关推荐
无限进步_7 小时前
【C语言&数据结构】对称二叉树:镜像世界的递归探索
c语言·开发语言·数据结构·c++·git·算法·visual studio
星辞树7 小时前
揭秘阿里 DIN:当深度学习遇上“千物千面”
算法
刘立军7 小时前
如何选择FAISS的索引类型
人工智能·算法·架构
小芒果_017 小时前
整理归并排序
c++·算法·排序算法·信息学奥赛
牛三金7 小时前
匿踪查询沿革-Private Information Retrieval(PIR)
算法·安全
德育处主任7 小时前
『NAS』在群晖部署一个文件加密工具-hat.sh
前端·算法·docker
星辞树8 小时前
从 L1/L2 到 Dropout:深度解析正则化,为何推荐系统“只能练一次”?
算法
玖剹8 小时前
队列+宽搜(bfs)
数据结构·c++·算法·leetcode·宽度优先
mit6.8248 小时前
01bfs|前缀和的前缀和
算法
wen__xvn8 小时前
代码随想录算法训练营DAY11第五章 栈与队列part02
算法