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;
    }
};
相关推荐
言存3 分钟前
力扣热题283 移动零
数据结构·算法·leetcode
字节高级特工12 分钟前
智能指针原理与使用场景全解析
开发语言·c++·算法
珊瑚里的鱼13 分钟前
【动态规划】买卖股票的最佳时机Ⅲ
算法·动态规划
逻辑星辰19 分钟前
x-ds-pow-response逆向分析
开发语言·人工智能·python·深度学习·算法
CQU_JIAKE29 分钟前
6.9【aAAA]
算法
Lewiis34 分钟前
白话桶排序
数据结构·算法·golang·排序算法
非生而知之者36 分钟前
基于灰狼算法优化的电量预测
python·算法·群体智能算法·电力预测
ywl47081208740 分钟前
‌HashMap 1.8 的扩容机制(Resize)‌
算法·哈希算法
_Evan_Yao1 小时前
递归函数入门:以阶乘和斐波那契数列为例
python·学习·算法
DFT计算杂谈1 小时前
WannierTools输入文件wt.in一键批量生成脚本
java·前端·chrome·python·算法·conda