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;
    }
};
相关推荐
handler013 分钟前
滑动窗口(同向双指针)算法:模板与例题解析
c语言·c++·笔记·算法·蓝桥杯·双指针·滑动窗口
Brilliantwxx6 分钟前
【算法题】基础计算器的不同实现方式
c++·算法
Sunsets_Red8 分钟前
P12375 「LAOI-12」MST? 题解
c++·算法·洛谷·信息学·oier·洛谷题解
_深海凉_27 分钟前
LeetCode热题100-二叉树的直径
算法·leetcode·职场和发展
shylyly_28 分钟前
大小端字节序
数据结构·算法·联合体·大小端字节序·字节序判断
mmz120731 分钟前
深度优先搜索DFS3(c++)
c++·算法·深度优先
水蓝烟雨32 分钟前
3373. 连接两棵树后最大目标节点数目 II
算法·leetcode
故事和你9133 分钟前
洛谷-【图论2-1】树6
开发语言·数据结构·c++·算法·深度优先·动态规划·图论
sali-tec34 分钟前
C# 基于OpenCv的视觉工作流-章73-点-线距离
图像处理·人工智能·opencv·算法·计算机视觉
不知名的老吴35 分钟前
在C++中不用宏怎么打日志的使用建议
开发语言·c++·算法