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;
    }
};
相关推荐
czlczl2002092513 小时前
算法:二叉树的公共祖先
算法
稚辉君.MCA_P8_Java14 小时前
Gemini永久会员 Java动态规划
java·数据结构·leetcode·排序算法·动态规划
小白程序员成长日记14 小时前
2025.11.23 力扣每日一题
算法·leetcode·职场和发展
16_one15 小时前
autoDL安装Open-WebUi+Rag本地知识库问答+Function Calling
人工智能·后端·算法
散峰而望16 小时前
C++数组(三)(算法竞赛)
开发语言·c++·算法·github
q***952216 小时前
SpringMVC 请求参数接收
前端·javascript·算法
初级炼丹师(爱说实话版)17 小时前
多进程与多线程的优缺点及适用场景总结
算法
hetao173383717 小时前
2025-11-25~26 hetao1733837的刷题记录
c++·算法
历程里程碑17 小时前
各种排序法大全
c语言·数据结构·笔记·算法·排序算法
少许极端17 小时前
算法奇妙屋(十四)-简单多状态dp问题
算法·动态规划·图解算法·简单多状态dp·打家劫舍问题·买卖股票问题全解