2024.4.19力扣每日一题——准时抵达会议现场的最小跳过休息次数

2024.4.19

      • 题目来源
      • 我的题解
        • 方法一 动态规划+浮点数精度
        • 方法二 动态规划+不考虑浮点数精度问题

题目来源

力扣每日一题;题序:1883

我的题解

方法一 动态规划+浮点数精度

参考官方题解。
用 f[i][j]表示经过了 dist[0]到 dist[i−1]的 i 段道路,并且跳过了 j 次的最短用时。
在进行状态转移时,考虑最后一段道路 dist[i−1]是否选择跳过:

  • 如果没有跳过,那么状态转移方程为:
          f [ i ] [ j ] = ⌈ f [ i − 1 ] [ j ] + dist [ i − 1 ] speed ⌉ f[i][j] = \left\lceil f[i-1][j] + \frac{\textit{dist}[i-1]}{\textit{speed}} \right\rceil f[i][j]=f[i1][j]+speeddist[i1]
    其中 ⌈x⌉表示将 x向上取整。对于最后一段道路,无需等待到下一个整数小时,但由于题目中给定的 hoursBefore是一个整数,因此在状态转移方程中向上取整是不会影响结果的。
  • 如果跳过,那么状态转移方程为:
        f [ i ] [ j ] = f [ i − 1 ] [ j − 1 ] + dist [ i − 1 ] speed f[i][j] = f[i-1][j-1] + \frac{\textit{dist}[i-1]}{\textit{speed}} f[i][j]=f[i1][j1]+speeddist[i1]

由于到达的时间尽可能早,因此需要选择这两种转移中的较小值,即:
f [ i ] [ j ] = min ⁡ { ⌈ f [ i − 1 ] [ j ] + dist [ i − 1 ] speed ⌉ , f [ i − 1 ] [ j − 1 ] + dist [ i − 1 ] speed } f[i][j] = \min \left\{ \left\lceil f[i-1][j] + \frac{\textit{dist}[i-1]}{\textit{speed}} \right\rceil, f[i-1][j-1] + \frac{\textit{dist}[i-1]}{\textit{speed}}\right\} f[i][j]=min{f[i1][j]+speeddist[i1],f[i1][j1]+speeddist[i1]}
需要注意的是,当 j=0 时,不能通过「跳过」进行转移;当 j=i 时,不能通过「没有跳过」进行转移;当 j>i 时,无法在 i 段道路内跳过超过 i 次,对应的状态不合法。
当计算完所有状态的值后,只需要找到最小的 j,使得 f[n][j]≤hoursBefore,这个 j即为最少需要跳过的次数。如果不存在这样的 jjj,那么返回 −1。
动态规划的细节

  • 动态规划的边界条件为 f[0][0]=0,表示初始(未走过任何道路)时的时间为 0。
    由于状态转移方程中的取值为 min⁡,因此可以将除了 f[0][0]以外所有的状态置为一个极大值 ∞ \infty ,方便进行转移。
    浮点数精度问题
    引入常量 eps表示一个极小值。在进行「向上取整」运算前,将待取整的浮点数减去 eps再进行取整,就可以避免上述的误差。
    同时,需要说明 eps 不会引入其它的问题。在本题中速度最大为 1 0 6 10^6 106,时间与速度成反比,那么 eps 的粒度只需要高于时间的精度 1 0 − 6 10^{-6} 106即可,取 1 0 − 7 10^{-7} 107 1 0 − 8 10^{-8} 108 都是可行的。
    最后在比较 f[n][j]≤hoursBefore时,也需要将左侧减去 eps或将右侧加上 eps,再进行比较。
    时间复杂度:O( n 2 n^2 n2)
    空间复杂度:O( n 2 n^2 n2)
public int minSkips(int[] dist, int speed, int hoursBefore) {
    int n=dist.length;
    double eps=1e-7;
    double[][] dp=new double[n+1][n+1];
    for(int i=0;i<=n;i++){
        Arrays.fill(dp[i],Double.MAX_VALUE);
    }
    dp[0][0]=0;
    for(int i=1;i<=n;i++){
        //跳跃次数
        for(int j=0;j<=i;j++){
            if(j!=i){
                dp[i][j]=Math.min(dp[i][j],Math.ceil(dp[i-1][j]+(double)dist[i-1]/speed-eps));
            }
            if(j!=0){
                dp[i][j]=Math.min(dp[i][j],dp[i-1][j-1]+(double)dist[i-1]/speed);
            }
        }
    }
    for(int i=0;i<=n;i++){
        if(dp[n][i]<hoursBefore+eps)
            return i;
    }
    return -1;
}
方法二 动态规划+不考虑浮点数精度问题

对所有的除法都乘以speed使其成为整数。将「必须休息并等待,直到下一个整数小时才能开始继续通过下一条道路」,那么当我们将上面的变量都乘以 speed 后,规定应当变更为「必须休息并等待,直到下一个 speed 的倍数小时才能开始继续通过下一条道路

时间复杂度:O( n 2 n^2 n2)
空间复杂度:O( n 2 n^2 n2)

public int minSkips(int[] dist, int speed, int hoursBefore) {
    int n=dist.length;
    long[][] dp=new long[n+1][n+1];
    for(int i=0;i<=n;i++){
        Arrays.fill(dp[i],Long.MAX_VALUE);
    }
    dp[0][0]=0;
    for(int i=1;i<=n;i++){
        //跳跃次数
        for(int j=0;j<=i;j++){
            if(j!=i){
                dp[i][j] = Math.min(dp[i][j], ((dp[i - 1][j] + dist[i - 1] - 1) / speed + 1) * speed);
            }
            if(j!=0){
                dp[i][j]=Math.min(dp[i][j],dp[i-1][j-1]+dist[i-1]);
            }
        }
    }
    for(int i=0;i<=n;i++){
        if(dp[n][i]<=(long)hoursBefore*speed)
            return i;
    }
    return -1;
}

有任何问题,欢迎评论区交流,欢迎评论区提供其它解题思路(代码),也可以点个赞支持一下作者哈😄~

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

C++奇迹之旅:深入理解赋值运算符重载

文章目录 &#x1f4dd;赋值运算符重载&#x1f320; 运算符重载&#x1f309;特性 &#x1f320; 赋值运算符重载&#x1f320;传值返回&#xff1a;&#x1f320;传引用赋值&#xff1a;&#x1f309;两种返回选择&#x1f309;赋值运算符只能重载成类的成员函数不能重载成全…

用Gold-yolo模块改进yolov8模型

gold-yolo论文&#xff1a; https://arxiv.org/pdf/2309.11331.pdf gold-yolo代码&#xff1a; https://github.com/huawei-noah/Efficient-Computing/tree/master/Detection/Gold-YOLO 一 gold模块简介 Gold-Yolo是华为诺亚方舟实验室2023年发布的工作&#xff0c;主要优化检…

Linux程序的地址空间,进程终止

个人主页&#xff1a;点我进入主页 专栏分类&#xff1a;C语言初阶 C语言进阶 数据结构初阶 Linux C初阶 算法 欢迎大家点赞&#xff0c;评论&#xff0c;收藏。 一起努力&#xff0c;一起奔赴大厂 一.程序的地址空间 1.1程序的地址空间的引入 我们知道frok可以创建…

重塑我们对随机性在计算中的作用的理解

2023年图灵奖&#xff0c;最近刚刚颁给普林斯顿数学教授 Avi Wigderson&#xff01;作为理论计算机科学领域的领军人物&#xff0c;他对于理解计算中的随机性和伪随机性的作用&#xff0c;作出了开创性贡献。 Avi Wigderson 的履历 自 1999 年以来&#xff0c;Wigderson 一直担…

Python五子棋VS人机对战

上一次编写了一个python五子棋游戏,但是属于玩家之间的对战。今天介绍五子棋和人机对战。本博文目的是教学和一些毕业设计。 目前电脑下棋逻辑算法还是比较简单的,不能和市面上五子棋相提并论,请大家理想对待! 代码: import pygame import sys import tkinter as tk fro…

再拓信创版图-Smartbi Insight V11与东方国信CirroData数据库完成兼容适配认证

近日&#xff0c;思迈特商业智能与数据分析软件 [简称&#xff1a;Smartbi Insight] V11与北京东方国信科技股份有限公司 &#xff08;以下简称东方国信&#xff09;CirroData-OLAP分布式数据库V2.14.1完成兼容性测试。经双方严格测试&#xff0c;两款产品能够达到通用兼容性要…

python语言零基础入门——注释、print()函数、input()函数

目录 一、注释 1.块注释 2.行内注释 3.多行注释 二、打印变量 1.print()函数&#xff1a;输出/打印指定内容 2.input()函数&#xff1a;输入指定内容 三、编程题&#xff1a;个人名片 一、注释 1.块注释 以#开始&#xff0c;直到本行结束都是注释为了保证代码的可读性…

初步学习node.js文件模块

环境已安装好&#xff1b; 写一个read1.js如下&#xff1b; var fs require("fs"); var data ;// 创建一个流 var stream1 fs.createReadStream(test1.jsp); stream1.setEncoding(UTF8);// 绑定data事件 stream1.on(data, function(mydata) {data mydata; });/…

Unity ECS

一&#xff1a;前言 ECS与OOP不同&#xff0c;ECS是组合编程&#xff0c;而OOP的理念是继承 E表示Entity&#xff0c;每个Entity都是一个有唯一id的实体。C表示Component&#xff0c;内部只有属性&#xff0c;例如位置、速度、生命值等。S表示System&#xff0c;驱动实体的行为…

Leetcode. 12 整数转罗马数字

罗马数字包含以下七种字符&#xff1a; I&#xff0c; V&#xff0c; X&#xff0c; L&#xff0c;C&#xff0c;D 和 M。 字符 数值 I 1 V 5 X 10 L 50 C 100 D 500 M 1000 例…

原来我一直被骗了!Burp suite诱导劫持攻击【附工具】

一、点击劫持 点击劫持是一种基于界面的攻击&#xff0c;用户通过点击诱饵网站中的一些其他内容被诱骗点击隐藏网站上的可操作内容。举例来说&#xff0c;一个网络用户可能会访问一个诱饵网站&#xff08;可能是通过电子邮件提供的链接&#xff09;&#xff0c;并点击一个按钮以…

C语言---贪吃蛇(二)---逻辑和代码的实现

文章目录 前言1.准备工作2.蛇的相关属性3.游戏流程设计3.1.游戏开始(GameStart)3.1.1.设置光标位置3.1.2.隐藏光标3.1.3.打印欢迎界面3.1.4.创建地图3.1.5.初始化蛇身3.1.6.创建食物 3.2.游戏运行(GameRun)3.2.1.打印信息栏3.2.2.蛇身的移动3.2.2.1.判断下一个结点是否为食物3.…

【Linux】iptables的应用

iptables 防火墙 防火墙是一种网络安全系统&#xff0c;它位于内部网络与外部网络&#xff08;如互联网&#xff09;之间&#xff0c;通过实施预定义的安全策略来控制网络间的通信。防火墙的主要目标是保护内部网络资源免受未经授权的访问、攻击或潜在威胁&#xff0c;同时允…

FFmpeg源码编译

msys2 依赖环境安装 依赖环境安装编译X264编译 fdk-aac文件处理编译x265编译FFmpeg 依赖环境安装 编译X264 用于h264 AVC视频格式编码 CCcl ./configure --enable-shared #指定使用cl,编译成动态链接库 make -j32 #使用32线程进行编码 make install命令一 关于第一条命令执…

VUE的import store from ‘./vuex/store改为‘ import store from ‘./vuex/store.js‘

ERROR Failed to compile with 1 error 下午5:25:40 error in (webpack)-dev-server/client?http://10.18.173.180:8081/sockjs-node Syntax Error: no such file or directory, open D:\4myroom\H…

2024年,新手做抖店千万犯这几点错误,轻则保证金,重则封店!

哈喽~我是电商月月 很多做抖音小店的新手朋友都忽略了违规操作这一部分&#xff0c;交完保证金以为后续不开了保证金还能退回&#xff1f;别天真了&#xff01; 不了解抖音小店的行为规则&#xff0c;违规了不仅保证金没了&#xff0c;严重的话&#xff0c;店铺都开不下去&am…

【精简改造版】大型多人在线游戏BrowserQuest服务器Golang框架解析(2)——服务端架构

1.架构选型 B/S架构&#xff1a;支持PC、平板、手机等多个平台 2.技术选型 &#xff08;1&#xff09;客户端web技术&#xff1a; HTML5 Canvas&#xff1a;支持基于2D平铺的图形引擎 Web workers&#xff1a;允许在不减慢主页UI的情况下初始化大型世界地图。 localStorag…

谷雨,春天的最后一次回眸

人生并不像火车要通过每个站似的经过每一个生活阶段。 今日谷雨&#xff0c;这不是技术文&#xff0c;是码哥的碎碎念 谷雨猕漫着芭蕉的味道动了心成了情白素贞的姻以伞结缘可天若无雨地上无伞断桥未断过客&#xff0c;能留下一段传奇吗&#xff1f;或许难难 倘若在江城边不是西…

盲人购物指南:智能化辅助引领超市购物新体验

作为一名资深记者&#xff0c;我有幸见证了一位盲人朋友借助一款名为蝙蝠避障的高科技辅助应用&#xff0c;独立完成超市购物之旅&#xff0c;这一过程充分展示了盲人购物指南新时代的到来。 在前往超市的路上&#xff0c;这款应用犹如一位贴心的“电子向导”&#xff0c;实时为…

编程范式之函数编程

文章目录 **核心概念****特征****优点****示例语言**案例 函数编程&#xff08;Functional Programming, FP&#xff09;是一种编程范式&#xff0c;它强调程序由一系列不可变的值和纯函数&#xff08;Pure Function&#xff09;组成&#xff0c;尽量避免副作用&#xff08;Sid…