[leetcode 1723] 完成所有工作的最短时间

news2024/9/22 9:36:39

题目

题目:https://leetcode.cn/problems/find-minimum-time-to-finish-all-jobs/description/
该题和 [leetcode 2305] 公平分发饼干 完全相同。

在这里插入图片描述

解法

回溯+剪枝

感觉和 [leetcode 198] 划分为k个相等的子集 有点相似,这题更像是划分为k个尽量相等的子集。使用回溯的话,需要检查数据范围,即数组jobs的长度,一般不能超过 20,否则会超时

代码基本上也是改编自 [leetcode 198],主要是回溯+剪枝,其中有三处剪枝和一处排序比较重要:

  • 如果已经超过最小值,无需继续向下递归;
  • 如果当前桶和上个桶相同且该桶不是第一个,无需继续向下递归(此类题目必备剪枝);
  • 为了尽量相等,超过平均值后,无需继续向下递归;
  • 数组降序排列,加快速度(此类题目必备);

这里特别说明一下为什么需要降序排列,如果数组为 1,1,1,2,2,2,分成3组,每组的值应该为3,如果没有降序,回溯时会遇到3个1在同一个桶内,另外两个桶是2,最后一个2没法放,需要回溯到第一层栈,非常浪费时间。

class Solution {
public:
    int ans;
    void backtracking(vector<int>& jobs, vector<int>& subs, int targ, int cur) {
        int len = jobs.size();
        if (cur == len) {
            int dis = 0;
            for (int sub : subs) {
                dis = max(dis, sub);
            }
            ans = min(ans, dis);
            return ;
        }
        int n = subs.size();
        for (int i = 0; i < n; i++) {
        	// 第一处剪枝:如果已经超过最小值,无需继续向下递归
            if (subs[i] > ans) {
                return ;
            }
            // 第二处剪枝:如果当前桶和上个桶相同且该桶不是第一个,该桶无需继续向下递归
            if (i > 0 && subs[i] == subs[i-1]) {
                continue;
            }
            // 第三处剪枝:为了尽量相等,超过平均值后,无需继续向下递归
            if (subs[i] < targ) {
                subs[i] += jobs[cur];
                backtracking(jobs, subs, targ, cur+1);
                subs[i] -= jobs[cur];
            }
        }
    }
    int distributejobs(vector<int>& jobs, int k) {
        int sum = accumulate(jobs.begin(), jobs.end(), 0);
        // 降序排列,加快速度
        sort(jobs.begin(), jobs.end(), greater<int>());
        vector<int> subs(k, 0);
        int targ = sum / k;
        ans = INT_MAX;
        backtracking(jobs, subs, targ, 0);
        return ans;
    }
};

二分+回溯

一定会有一个桶分到数组最大值,故最终结果一定不低于该数组最大值;假设只有一个桶,数组中所有值只能放在该桶内,最终结果一定不超过数组总和。我们可以通过二分查找,在上面两个值范围内,找到满足题意的最小值!如何判断某个值是否满足题意(即每桶的值均不超过该值)呢,使用回溯。这种方法比上面更快,速度可以击败100%。

class Solution {
public:
    int ans;
    bool backtracking(vector<int>& jobs, vector<int>& subs, int targ, int cur) {
        int len = jobs.size();
        if (cur == len) {
            return true;
        }
        int n = subs.size();
        for (int i = 0; i < n; i++) {
        	// 剪枝:如果当前桶和上个桶相同且该桶不是第一个,该桶无需继续向下递归
            if (i > 0 && subs[i] == subs[i-1]) {
                continue;
            }
            if (subs[i] + jobs[cur] <= targ) {
                subs[i] += jobs[cur];
                bool res = backtracking(jobs, subs, targ, cur+1);
                if (res) {
                    return true;
                }
                subs[i] -= jobs[cur];
            }
        }
        return false;
    }
    int minimumTimeRequired(vector<int>& jobs, int k) {
        int sum = accumulate(jobs.begin(), jobs.end(), 0);
        // 降序排列,加快速度
        sort(jobs.begin(), jobs.end(), greater<int>());
        int low = jobs[0], high = sum;
        int ans = 0;
        while (low <= high) {
            int mid = (high + low) >> 1;
            vector<int> subs(k, 0);
            bool res = backtracking(jobs, subs, mid, 0);
            if (res) {
                high = mid - 1;
                ans = mid;
            }
            else {
                low = mid + 1;
            }
        }
        return ans;
    }
};

状压+dp

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/171938.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

easypoi 模板导入、导出合并excel单元格功能

easypoi 模板导入、导出合并单元格功能 参考&#xff1a; java使用poi读取跨行跨列excel springboot集成easypoi并使用其模板导出功能和遇到的坑 Easypoi Excel模板功能简要说明 easypoi 模板导出兼容合并单元格功能 ExcelUtil package com.yymt.utils;import cn.aftertu…

linux系统中利用QT实现环境传感器的数据获取方法

大家好&#xff0c;今天主要和大家分享一下&#xff0c;如何使用QT实现对三合一环境传感器的数据的获取和实现。 目录 第一&#xff1a;资源介绍 第二&#xff1a;具体代码的详细实现 第三&#xff1a;源文件“mainwindow.h”实现 第四&#xff1a;Linux应用接口获取数据 第…

大趋势:科技赋能产业

能整合传统产业资源的老板大优势&#xff01; 三大趋势&#xff1a; 科技赋能产业链 乡村振兴 文化复兴 纯技术类企业在产业链方面不占优势 趣讲大白话&#xff1a;时势造英雄 ******** 消费互联网竞争太卷了 竞争向产业升级方向转移 向高质量发展导向 乡村振兴是整合分散的集…

容器虚拟化技术Docker(一)简介、安装、常见命令、数据卷、安装常规软件

容器虚拟化技术Docker&#xff08;一&#xff09;简介、安装、常见命令、数据卷、安装常规软件 1、Docker简介 1、简介 Docker的主要目标是“Build&#xff0c;Ship and Run Any App,Anywhere”&#xff0c;也就是通过对应用组件的封装、分发、部署、运行等生命周期的管理&a…

web3:同态加密

web3相关学习一并收录至该博客&#xff1a;web3学习博客目录大全 目录同态加密概念同态加密具体如何定义&#xff1f;主流同态加密算法原理乘法同态加密算法① RSA算法一些基本的数学知识RSA的具体过程秘钥的产生加密解密验证了 RSA 算法的乘法同态性java代码简单实现python代码…

保时捷狂推NFT,高调喊出打造Web3社区,Web2品牌“天生缺陷”终将折戟沉沙?...

图片来源&#xff1a;由无界 AI 绘画工具生成2023年1月&#xff0c;保时捷中国的公关团队“忙疯”了&#xff0c;一连搞了好几个活动。有展览&#xff0c;媒体连线直播&#xff0c;甚至搞起了一场有圆桌&#xff0c;有嘉宾主题演讲的发布会。目的只有一个&#xff0c;告诉中国用…

6、Ubuntu20的JDKMySQLtomcatRedisNginx安装

安装JDK 这里以安装版本8为例 进入存放jdk目录创建目录 cd /usr/local mkdir jdk cd jdk 把下好的jdk8压缩包拖拽到Ubuntu连接用户下 移动jdk包文件 mv /home/starfish/jdk-8u351-linux-x64.tar.gz . 解压jdk tar -zxvf jdk-8u351-linux-x64.tar.gz cd jdk1.8.0_351/ p…

ubuntu20.04安装搜狗sogou输入法

环境 Ubuntu20.04 Sogou拼音输入法安装过程 Step.1 安装fcitx框架 sudo apt-get update sudo apt-get install fcitx输入winA后&#xff0c;打开Languate Support Keyboard input method system中&#xff0c;选择fcitx 点击Install/RemoveLanguates...&#xff0c;选择Ch…

面向物流行业的文档管理系统

用于运输和物流的 DocuWare 文档管理软件 物流和货运行业的效率激烈战在公路、火车、货船和空中展开。DocuWare 的快速、安全和灵活的文档管理是真正的竞争优势。在您的公司和客户的核心流程中节省新的成本和时间。 一、数字化和文档管理软件改变了物流公司的游戏规则 智能链…

PostgreSQL 技术内幕(五)Greenplum-Interconnect模块

Greenplum是在开源PostgreSQL的基础上&#xff0c;采用MPP架构的关系型分布式数据库。Greenplum被业界认为是最快最具性价比的数据库&#xff0c;具有强大的大规模数据分析任务处理能力。 Greenplum采用Shared-Nothing架构&#xff0c;整个集群由多个数据节点&#xff08;Segm…

mycat数据分片

Mycat是一个彻底开源的&#xff0c;面向企业应用开发的大数据库集群。它的定义是是一个开源的分布式数据库系统&#xff0c;是一个实现了MySQL协议的服务器&#xff0c;前端用户可以把它看作是一个数据库代理&#xff0c;用MySQL客户端工具和命令行访问&#xff0c;而其后端可以…

【题解】2023牛客寒假算法基础集训营1

目录A. World Final? World Cup! (I)思路B. World Final? World Cup! (II)C. 现在是&#xff0c;学术时间 (I)思路D. 现在是&#xff0c;学术时间 (II)思路E. 鸡算几何思路F. 鸡玩炸蛋人思路G. 鸡格线思路H. 本题主要考察了DFS思路I. 本题也主要考察了DFSJ. 本题竟也主要考察…

MySQL详细教程,2023硬核学习路线,看这一篇就够了

文章目录前言1. 数据库的相关概念1.1 数据1.2 数据库1.3 数据库管理系统1.4 数据库系统1.5 SQL2. MySQL数据库2.1 MySQL安装2.2 MySQL配置2.2.1 添加环境变量2.2.2 新建配置文件2.2.3 初始化MySQL2.2.4 注册MySQL服务2.2.5 启动MySQL服务2.3 MySQL登录和退出2.4 MySQL卸载2.5 M…

PR基础知识

sh什么是帧&#xff0c;什么是帧速率&#xff0c;什么是方形像素? 什么叫场序? # 时长 s时i长为视频时间得长度&#xff0c;基本单位为秒。但是在PR软件中。有更为精准得时间单位计算为帧。也就是说把1秒分为若干份。一份就是一帧。一帧也就可以理解为一张图片。 s所以在PR…

联合证券|未来五年是“大信创”发展的关键时期 发展空间广阔

机构指出&#xff0c;展望2023年&#xff0c;信创将从党政信创走向全面信创&#xff08;28N&#xff09;&#xff0c;叠加方针催化及疫情预期转变&#xff0c;泛信创范畴有望成为板块主线&#xff0c;孕育出许多板块的出资机会。 中心逻辑 1、2022年计算机职业大都子板块的增长…

用户行为收集到HIVE

2.3 用户行为收集到HIVE 目标 目标 知道收集用户日志形式、流程知道flume收集相关配置、hive相关配置知道supervisor开启flume收集进程管理应用 应用supervisor管理flume实时收集点击日志 2.3.1 为什么要收集用户点击行为日志 用户行为对于某项目文章推荐来说&#xff0c;至…

京东方尚未成为苹果的最大供应商,但已经享受到果链的好处

在知名分析师郭明錤表示京东方今年将成为苹果iPhone15的OLED面板主力供应商后&#xff0c;业界纷纷期待京东方在中小尺寸OLED面板市场的份额激增&#xff0c;目前虽然京东方尚未真正开始向苹果供应iPhone15的OLED面板&#xff0c;但它已开始享受到果链带来的好处。京东方量产OL…

嵌入式C语言设计模式 --- 装饰器模式

1 - 什么是装饰器模式? 装饰器模式(Decorator Pattern),是结构型设计模式的一种,装饰器模式允许向一个现有的对象添加新的功能,而又不改变其对象结构,这种方式比使用子类继承的方式更加灵活。 装饰,顾名思义,就是在原有事物的基础上,锦上添花地新增某些点缀或功能,…

[ROS2 入门] rqt_console 使用介绍

大家好&#xff0c;我是虎哥&#xff0c;从今天开始&#xff0c;我将花一段时间&#xff0c;开始将自己从ROS1切换到ROS2&#xff0c;在上一篇中&#xff0c;我们一起了解ROS 2中“Actions ”概念&#xff0c;至此最基本的核心基础概念&#xff0c;我们就都分享介绍完毕了&…

③【Spring】整合第三框架的常用机制:FactoryBean

个人简介&#xff1a;Java领域新星创作者&#xff1b;阿里云技术博主、星级博主、专家博主&#xff1b;正在Java学习的路上摸爬滚打&#xff0c;记录学习的过程~ 个人主页&#xff1a;.29.的博客 学习社区&#xff1a;进去逛一逛~ FactoryBean 机制一、什么是 FactoryBean &…