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;
    }
};
相关推荐
charlie114514191几秒前
嵌入式现代C++开发——三路比较运算符
开发语言·c++·学习·算法·嵌入式·编程指南
2401_90015154几秒前
C++编译期正则表达式
开发语言·c++·算法
倾心琴心1 分钟前
【agent辅助pcb routing coding学习】实践1 kicad pcb 格式讲解
算法·agent·pcb·eda·routing
仙俊红2 分钟前
LeetCode493周赛T3,前后缀分解
数据结构·算法·leetcode
_日拱一卒5 分钟前
LeetCode(力扣):二叉树的前序遍历
java·数据结构·算法·leetcode
倾心琴心5 分钟前
【agent辅助pcb routing coding学习】实践5 kicad类按类别理解
算法·agent·pcb·eda·routing
Frostnova丶8 分钟前
LeetCode 50. Pow(x, n)
算法·leetcode
lierenvip13 分钟前
【语义分割】12个主流算法架构介绍、数据集推荐、总结、挑战和未来发展
算法·架构
三块可乐两块冰18 分钟前
机器学习笔记一
笔记·算法·机器学习
凤年徐22 分钟前
优选算法——滑动窗口2
数据结构·c++·算法