备战蓝桥杯Day31 - 真题-管道

题目描述

 解题思路

这个问题可以视为一个水波在管道中传播的问题,其中水波以单位速度传播。阀门在 S 时刻打开,水流以单位速度流向管道的右侧,每个传感器位于每段管道的中心。对于位于 Li 的阀门,在 Ti 时刻打开时,水波会在 Ti - S 时刻到达第 Li 段,并继续向右传播。

我们需要找到这样一个时刻,使得所有的传感器都检测到水流。由于水波是以单位速度传播的,我们可以按照阀门打开的时刻和水波传播的距离来计算每个传感器检测到水流的时刻。最早所有传感器都检测到水流的时刻,就是最后一个传感器检测到水流的时刻。

大佬题解

我觉得他这个代码思路非常清晰,而且跟我的思路一模一样,不过我写不出。

import os
import sys

# 请在此输入您的代码

# import time


def check(Ti, values, Len):
    """
    逐步缩小时间,寻找满足所有管道都能检测到水流时的最小时刻
    :param Ti:管道中每一段中间的传感器都能检测到有水流的时间
    :param values:最初打开的阀门与打开时刻点
    :param Len:管道长度
    :return:True or False
    """
    # 存储通过已打开的阀门,在Ti时刻能检测到水流的管道段
    section = []

    # 遍历每个已打开的阀门,计算并存入能检测到水流的管道段
    for Li, Si in values:
        if Ti >= Si:
            section.append((Li - (Ti - Si), Li + (Ti - Si)))

    # 将管道段按左边界升序排序
    section.sort()

    # 如果没有管道段或者第一个管道段的左边界大于1,即此Ti无法满足所有管道段都能检测到水流,上一个Ti为最小所求时间
    if not section or section[0][0] > 1:
        return False

    # 初始化最大右边界为第一个管道段的右边界
    right_boundary = section[0][1]

    # 遍历管道段,合并相邻的管道段
    for i in range(1, len(section)):
        if section[i][0] - right_boundary <= 1:  # 将管道段的左值与最大右边界比较
            right_boundary = max(right_boundary, section[i][1])  # 差值不大于1则更新最大右边界
        else:
            break

    # 如果最终的右边界大于等于管道长度,返回True,否则返回False
    return right_boundary >= Len


def main():
    # 输入已开启阀门数,管道总长度
    n, Len = map(int, input().split())
    # 输入阀门编号与开启时间
    values = [list(map(int, input().split())) for _ in range(n)]

    # start_time = time.perf_counter()

    # 初始化二分查找的左右边界
    left, right = 0, 10 ** 9

    # 二分查找
    while left < right:
        mid = (left + right) // 2
        if check(mid, values, Len):
            right = mid
        else:
            left = mid + 1

    # 输出结果
    print(left)

    # end_time = time.perf_counter()
    # print(f'用时{(end_time - start_time) * 1000}毫秒')


if __name__ == '__main__':
    main()

 我的解题过程

根据题目我画出了示意图,弄清楚题目中给出字母所代表的意思,根据题目中给出的输入数据和输出数据,我大致明白题目的意思,明白人应该怎么解题,但是在实现代码上能力还不太够。还是需要看大佬怎么写出代码的。

明白题目的意思和思路后解题其实不难,主要是写代码要多练和多运用。题目中用到二分查找,我知道二分查找的算法,但是不知道什么时候要运用这个算法,怎么运用。我再多练习练习,看我能不能自己写出来吧。

菜就多练!

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

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

相关文章

Docker Desktop 安装 ClickHouse 超级简单教程

Docker desktop 安装 clickhouse 超级简单 文章目录 Docker desktop 安装 clickhouse 超级简单 什么是 Docker &#xff1f;安装下准备安装Docker配置安装 ClickHouse配置数据库密码DBeaver 测试创建表总结 什么是 Docker &#xff1f; 下载 Docker desktop Docker Desktop …

网络编程:多点通信+域套接字

一、多点通信 1.网络属性 getsockopt和setsockopt int getsockopt(int sockfd, int level, int optname, void *optval, socklen_t *optlen); int setsockopt(int sockfd, int level, int optname, const void *optval, socklen_t optlen); 功能&#xff1a;获取或设置套接字…

【Pt】ID贴图的基本使用

目标 将小白人样本的脸部区域填充为红色&#xff0c;如下 步骤 1. 首先这里打开一个软件自带的样本 2. 添加一个填充图层 3. 设置Base Color为红色 4. 添加黑色遮罩 5. 鼠标右键点击遮罩&#xff0c;然后添加颜色选择 6. 点击选取颜色就可以看到不同的ID部分 此时鼠标会变为滴…

个人信息的动态表单

有一系列需要勾选的内容&#xff0c;勾选完内容后&#xff0c;会根据勾选内容自动生成一个对应的表单。 不同的勾选内容&#xff0c;生成的表单内容是不一样的。 checkbox勾选方法&#xff1a; private void checkBox1_CheckedChanged(object sender, EventArgs e){this.te…

深入理解nginx连接数限制模块[下]

目录 4 源码分析4.1 配置指令源码分析4.1.1 limit_conn_zone4.1.2 limit_conn4.1.3 limit_conn_log_level4.1.4 limit_conn_status4.1.5 limit_conn_dry_run 4.2 共享内存初始化4.3 模块初始化4.4 请求处理4.5 红黑树的查找4.6 请求关闭的析构函数 关注我的微信公众号: 上接 …

DBSCAN聚类原理及Python实现

文章目录 一、相关术语二、DBSCAN原理2.1 算法思想及步骤2.2 优缺点分析2.3 Python代码 三、运行效率加速 一、相关术语 密度&#xff1a;指定半径内点的个数&#xff1b;核心点&#xff1a;如果某个点的半径邻域epsilon内至少包含minPts个点数&#xff0c;它就是核心点&#…

Spring Security的开发

文章目录 1,介绍2, 核心流程3, 核心原理3.1 过滤器链机制3.2 主体3.3 认证3.4 授权3.5 流程图4, 核心对象4.1 UserDetailsService 接口4.2 PasswordEncoder 接口4.3 hasAuthority方法4.4 hasAnyAuthority方法4.5 hasRole方法4.5 hasAnyRole方法5, 核心注解5.1 @PreAuthorize5.1…

十四、ReadWriteLock

ReadWriteLock 读写锁 又叫排他锁 如果使用互斥锁&#xff0c;一个线程在读&#xff0c;其他线程也不能读也不能写 换成读写锁的时候&#xff0c;读线程是读锁&#xff0c;写线程是写锁&#xff0c;写锁是排他的 在多线程大大提高效率&#xff0c;当一个线程在读的时候&…

MybatisPlus逆向工程

目录 &#x1f9c2;1.前提说明 &#x1f37f;2.引入依赖 &#x1f32d;3.使用导入模板 1.前提说明 注意 适用版本&#xff1a;mybatis-plus-generator 3.5.1 以下版本&#xff0c;3.5.1 及以上的请参考 3.5.1以上参考官网&#xff1a;3.5.1以上逆向工程 2.引入依赖 …

用 二层口 实现三层口 IP 通信的一个实现方法

我们一般用 undo portswitch 来将二层口转为三层口&#xff0c;但如果设备不支持的话&#xff0c;那么。。。 一、拓朴图&#xff1a; 二、实现方法&#xff1a; 起一个 vlan x&#xff0c;配置 vlanif地址&#xff0c;然后二层口划分到 vlan x 下&#xff0c;对端做同样的配置…

C语言 实用调试技巧

我们的博客已经更新到了数据结构&#xff0c;但是当我在深耕数据结构时我发现我在C语言是遗漏了一个重要的东西&#xff0c;那就是C语言的使用调试技巧。这篇博客对数据结构非常重要&#xff0c;请大家耐心观看。 1. 什么是bug&#xff1f; 第一次被发现的导致计算机错误的飞蛾…

Centos虚拟机忘记密码;重置虚机密码

虚拟机是一个好用的工具&#xff0c;在本地搭建的虚拟机可以给我们提供测试&#xff0c;但时间长了也会忘记密码&#xff1b;因此这里以centos系统的虚机为例&#xff0c;提供一个重置虚机密码的方法 1.在开机页面按“E”进入编辑模式 进入后长这样&#xff1a; 2.找到ro cras…

Python面向对象——架构设计【2】

练习1&#xff1a;打电话 请使用面向对象思想描述下列情景: 小明使用手机打电话,还有可能使用座机.... class People:def __init__(self,name):self.name namedef call_up(self,tool):print(self.name,end"")tool.call()class Tools:def __init__(self,way):self.wa…

【第十三章】改进神经网络学习方式-其他正则化技术

L1正则化 除了L2正则化之外&#xff0c;还有许多正则化技术。事实上&#xff0c;已经开发出了如此多的技术&#xff0c;以至于我不可能总结它们。在本节中&#xff0c;我简要介绍了三种减少过拟合的其他方法&#xff1a;L1正则化、dropout和人为增加训练集大小。我们不会像之前…

四.流程控制(顺序,分支,循环,嵌套)

c刚刚转过来的记得写在public static void main&#xff08;String[] args&#xff09;的花括号里 一.顺序结构 二.分支结构 if &#xff0c;switch 1.if (条件判断&#xff09; 2.if else 3.if else if else if ... else(它是一个一个否定来一个个执行判断的 4.s…

Gitee 实战配置

一、Gitee 注册帐号 官网&#xff1a;https://gitee.com点击注册按钮。填写姓名。填写手机号。填写密码。点击立即注册按钮 二、安装GIT获取公钥 1.官网下载git下载地址&#xff1a;https://git-scm.com/download/win 2.安装git&#xff0c;双击运行程序&#xff0c;然后一直下…

Android下的匀速贝塞尔

画世界pro里的画笔功能很炫酷 其画笔配置可以调节流量&#xff0c;密度&#xff0c;色相&#xff0c;饱和度&#xff0c;亮度等。 他的大部分画笔应该是通过一个笔头图片在触摸轨迹上匀速绘制的原理。 这里提供一个匀速贝塞尔的kotlin实现&#xff1a; class EvenBezier {p…

SD卡RAW故障解析与数据恢复全攻略

一、SD卡RAW现象解析 SD卡作为现代电子设备中常见的存储介质&#xff0c;其稳定性和可靠性直接关系到我们日常工作和生活的数据安全。然而&#xff0c;有时我们会遇到SD卡突然变成RAW格式的情况&#xff0c;这通常意味着SD卡的文件系统出现了严重的问题&#xff0c;导致无法正…

Python基础介绍 —— 使用pytest进行测试!

​编辑自动化测试 1319 篇文章62 订阅 订阅专栏 Pytest 是 Python 的一种单元测试框架&#xff0c;与 Python 自带的 unittest 测试框架类似&#xff0c;但是比 unittest 框架使用起来更简洁&#xff0c;效率更高。 Pytest 是一个成熟的全功能的 Python 测试工具&#xff0c;…

在VSCode中怎么配置Python开发环境?真的超简单!

前言&#xff1a;VS Code 里是不包括 Python 的&#xff0c;所以你首先得安装一个 Python。 1、终端运行 Python 安装完 python 之后&#xff0c;我们可以用任何一个文本编辑工具开始写 python 代码&#xff0c;然后在 cmd 中运行代码。 在 VS Code 中&#xff0c;在不安装任…