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;
    }
};
相关推荐
追随者永远是胜利者16 小时前
(LeetCode-Hot100)32. 最长有效括号
java·算法·leetcode·职场和发展·go
lifallen16 小时前
CDQ 分治 (CDQ Divide and Conquer)
java·数据结构·算法
追随者永远是胜利者16 小时前
(LeetCode-Hot100)31. 下一个排列
java·算法·leetcode·职场和发展·go
ValhallaCoder16 小时前
hot100-二分查找
数据结构·python·算法·二分查找
0 0 016 小时前
【C++】矩阵翻转/n*n的矩阵旋转
c++·线性代数·算法·矩阵
m0_5312371716 小时前
C语言-指针,结构体
c语言·数据结构·算法
癫狂的兔子16 小时前
【Python】【机器学习】十大算法简介与应用
python·算法·机器学习
丰海洋16 小时前
leetcode-hot100-1.两数之和
数据结构·算法·leetcode
苦藤新鸡16 小时前
58 单词搜索
数据结构·算法
_F_y16 小时前
背包问题动态规划
算法·动态规划