【vivo秋招0912】三、最少开发工时总和 <模拟>

三、最少开发工时总和

某开发小组近期承接了多个研发项目,作为组长的你需要为员工分配工作任务。具体要求如下:

项目划分到的任务工时用二维数组 tasks 表示,其中 tasks[i][j] 表示的是第 i 个项目中第 j 个任务的开发工时;现在组内员工有 n 个,每个工作任务只能分配给一位员工,一位员工可以被分配多个任务,一个任务完成才能进行下一个任务,且每个项目必须所有员工参与。

请为组内员工设计一套最合理的工作任务安排,使得每个项目中各员工的工作时长最接近,计算并返回每个项目中员工最少的开发工时总和。

注意:

1 <= n <= tasks[i].length <= 10

1 <= tasks[i][j] <= 30

示例输入:

java 复制代码
[[2,3,1],[1,2,6,2],[3,2]],2

输出:

java 复制代码
10

解释:

java 复制代码
总共2个员工
第1个项目[2,3,1],分给2个员工为[3],[2,1],最少的为 [3] 或 [2,1]
第2个项目[1,2,6,2],分给2个员工为[1,2,2],[6],最少的为[1,2,2]
第3个项目[3,2],分给2个员工为[3],[2],最少的为[2]
所有项目最少工作时长总和: 3+5+2=10

题解

思路:分配每个项目中任务,均匀分配为 n 份,取均匀分配完最小的那份。然后累加。

java 复制代码
	public int leastTimeSum (int[][] tasks, int n) {
	    int allCost = 0;
	
	    for(int[] mission: tasks){
	        int length = mission.length;
	        
	        // 分不了n份,说明最小那份是0
	        if(length<n){
	            continue;
	        }
	        Arrays.sort(mission);
	        
	        //对于每一个任务构造 n个槽,并且都是0
	        int[] nowCost = new int[n];
	        for(int i=0;i<n;i++){
	            nowCost[i]=0;
	        }
	        
	        for(int i =length-1;i>=0;i--){
	            //找槽总数最小的那个下标
	            int index = minIndex(nowCost);
	            //放进槽小的那个
	            nowCost[index] += mission[i];
	        }
	
	        // 加上槽最少的那组
	        allCost += nowCost[minIndex(nowCost)];
	
	    }
	    return allCost;
	}
	
	// 第几个槽 总数最小
	public static int minIndex(int[] array){
	    int min =array[0];
	    int index = 0;
	    for(int i =0;i<array.length;i++){
	        if(array[i]<min){
	            min = array[i];
	            index = i;
	        }
	    }
	    return index;
	}
相关推荐
吃好睡好便好6 小时前
在Matlab中绘制横直方图
开发语言·学习·算法·matlab
仰泳之鹅6 小时前
【C语言】自定义数据类型2——联合体与枚举
c语言·开发语言·算法
x_yeyue8 小时前
三角形数
笔记·算法·数论·组合数学
Mr. zhihao9 小时前
深入解析redis基本数据结构
数据结构·数据库·redis
念何架构之路9 小时前
Go语言加密算法
数据结构·算法·哈希算法
AI科技星10 小时前
《数学公理体系·第三部·数术几何》(2026 年版)
c语言·开发语言·线性代数·算法·矩阵·量子计算·agi
失去的青春---夕阳下的奔跑10 小时前
560. 和为 K 的子数组
数据结构·算法·leetcode
黎阳之光10 小时前
黎阳之光:以视频孪生重构智慧医院信息化,打造高标项目核心竞争力
大数据·人工智能·物联网·算法·数字孪生
丷丩11 小时前
三级缓存下MVT地图瓦片服务性能优化策略
算法·缓存·性能优化·gis·geoai-up
m0_6294947311 小时前
LeetCode 热题 100-----25.回文链表
数据结构·算法·leetcode·链表