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;
    }
};
相关推荐
亓才孓13 小时前
java中的Math.Radom拓展
开发语言·python·算法
霍田煜熙13 小时前
CBMS最新源码
算法
NAGNIP13 小时前
主流的激活函数有哪些?
算法
NAGNIP14 小时前
Self-Attention 为什么要做 QKV 的线性变换?又为什么要做 Softmax?
算法
core51214 小时前
PageRank 算法:互联网的“人气投票”
算法·pagerank
小白菜又菜14 小时前
Leetcode 1523. Count Odd Numbers in an Interval Range
算法·leetcode
你们补药再卷啦14 小时前
人工智能算法概览
人工智能·算法
cnxy18814 小时前
围棋对弈Python程序开发完整指南:步骤3 - 气(Liberties)的计算算法设计
python·算法·深度优先
AndrewHZ15 小时前
【图像处理基石】什么是光栅化?
图像处理·人工智能·算法·计算机视觉·3d·图形渲染·光栅化
小白菜又菜15 小时前
Leetcode 944. Delete Columns to Make Sorted
算法·leetcode