码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 蓝桥杯刷题day13——乘飞机【算法赛】


    一、问题描述

    等待登机的你看着眼前有老有小长长的队伍十分无聊,你突然想要知道,是否存在两个年龄相仿的乘客。每个乘客的年龄用一个 0 到 36500 的整数表示,两个乘客的年龄相差 365 以内就认为是相仿的。

    具体来说,你有一个长度为 n 的数组,每个数组元素都是一个 0∼36500 的整数。给出 q 个二元组 l,r,判断数组在区间 [l,r] 上是否存在两个差值小于等于 365 的数,若存在输出 YES,否则输出 NO。

    输入格式

    第一行两个整数 n,q,表示乘客数和询问数。

    接下来一行 n 个整数,表示乘客的年龄。

    接下来 q 行,每行两个整数 l,r 表示查询。

    输出格式

    q 行,每行输出 YES 或者 NO,分别表示区间内存在/不存在年龄相仿的乘客。

    样例输入

    6 3

    20 800 400 175 146 456

    1 3

    1 4

    1 6

    样例输出

    1. NO
    2. YES
    3. YES

    说明

    对于区间 [1,3],最小相邻为 400−20=380>365。

    二、解析

    这个问题可以通过遍历每个查询区间来解决。对于每个查询区间,我们需要检查区间内是否存在两个年龄相差不超过365的乘客。这里有两个关键点:

    1. 如果查询区间的长度本身就很大(大于或等于整个年龄范围 36500//365,即100),那么显然区间内至少存在两个年龄相差不超过365的乘客,因此可以直接输出"YES"。

    2. 如果查询区间的长度较小,我们需要对区间内的年龄进行排序,然后遍历排序后的列表,检查相邻年龄之间的差值。如果存在差值小于等于365的情况,即输出"YES"。如果遍历完整个列表都没有找到这样的差值,则输出"NO"。

    三、python代码

    1. n,q=map(int,input().split())
    2. age_ls=list(map(int,input().split()))
    3. q_ls=[]
    4. for i in range(q):
    5. a,b=map(int,input().split())
    6. q_ls.append([a-1,b-1])
    7. for i in range(q):
    8. l,r=q_ls[i]
    9. if r-l>=36500//365:
    10. print("YES")
    11. else:
    12. new_ls=sorted(age_ls[l:r + 1])
    13. for i in range(r-l):
    14. if new_ls[i+1]-new_ls[i]<=365:
    15. print("YES")
    16. break
    17. else:
    18. print("NO")

    四、运行结果

  • 相关阅读:
    如何在 Mac 上卸载 Java?
    基于C++的微流控生物芯片模拟程序设计
    【IoT】从马斯克造火箭到产品开发,快速失败很重要
    【Rust 指南】并发编程|无畏并发的原因
    Langchain-Chatchat项目:1-整体介绍
    2023年09月 C/C++(七级)真题解析#中国电子学会#全国青少年软件编程等级考试
    dvwa 代码注入impossible代码审计
    从源码全面解析 dubbo 服务端服务调用的来龙去脉
    墙裂推荐:GitHub 上这个开源项目可以让你在短短几分钟之内了解一门技术
    基于C++实现⾃然连接操作算法
  • 原文地址:https://blog.csdn.net/Python_1981/article/details/137250106
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号