按按钮题解

推荐在 cnblogs 上阅读

按按钮题解

在量体温,打不了代码,来写题解。

赞美 lwq,三句话让我跟上了课堂节奏。

题意

数轴 n n n 个按钮,第 i i i 个按钮在坐标 i i i。有 m m m 次询问, i i i 询问为在时刻 t i t_i ti 按下 b i b_i bi

可以在时刻 0 0 0 安排一些机器人,机器人可以花 1 1 1 单位时间向左或右移动 1 1 1 个单位。机器人按下按钮不需要时间。

问最初最少安排多少个机器人。

Solution

每个按钮在被按后,改点的机器人可以走到的范围是一个区间。

[ b i + M a x − t i , b i − ( M a x − t i ) ] [b_i+Max-t_i,b_i-(Max-t_i)] [bi+Maxti,bi(Maxti)]

其中 M a x Max Max 为最大的 t i t_i ti

接着,如果这些区间里存在一些小区间被一个大区间完全覆盖,那么这些小区间的任务可以都交给一个机器人去做。

思路到此就很清晰了,即求一个最小集,这个集合里都是互不完全包含的区间。答案即这个集合的大小。

怎么做呢?

区间按左端点从小到大、右区间从大到小排序,然后树状数组处理一下就好了。

时间复杂度 O ( n log ⁡ n ) O(n\log n) O(nlogn)

#include<bits/stdc++.h>
using namespace std;#define int long long
#define pii pair<int,int>
#define ft first
#define sd secondconst int N=5e6+5;int n,m;
int t[N],b[N];
pii a[N];
int tr[N];
int tmp[N],tot;
map<int,int> Hs;void add(int x,int k) {for(;x<=tot;x+=x&-x)tr[x]=max(tr[x],k);}int query(int x) {int c=0;for(;x;x-=x&-x)c=max(c,tr[x]);return c;}bool cmp(pii x,pii y)
{if(x.ft!=y.ft)return x.ft<y.ft;return x.sd>y.sd;
}signed main()
{scanf("%lld%lld",&n,&m);int Max=0;for(int i=1;i<=m;i++)scanf("%lld",&t[i]),Max=max(Max,t[i]);for(int i=1;i<=m;i++){scanf("%lld",&b[i]);tmp[++tot]=b[i]-(Max-t[i]);tmp[++tot]=b[i]+Max-t[i];}sort(tmp+1,tmp+tot+1);for(int i=1;i<=tot;i++)Hs[tmp[i]]=i;for(int i=1;i<=m;i++){a[i].ft=Hs[b[i]-(Max-t[i])];a[i].sd=Hs[b[i]+Max-t[i]];}sort(a+1,a+m+1,cmp);for(int i=1;i<=m;i++)add(a[i].sd,query(a[i].sd-1)+1);printf("%lld\n",query(tot));return 0;
}

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

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

相关文章

英伟达驱动重装教程

离线安装NVIDIA驱动程序通常涉及下载驱动程序安装包并手动执行安装步骤。以下是详细步骤: 1. 下载NVIDIA驱动程序 首先,你需要在有网络连接的计算机上下载适合你系统的NVIDIA驱动程序安装包。可以从NVIDIA官方驱动下载页面下载。 选择你的GPU型号和操作系统,然后下载相应…

Gradio 案例——将文本文件转为词云图

文章目录 Gradio 案例——将文本文件转为词云图界面截图依赖安装项目目录结构代码 Gradio 案例——将文本文件转为词云图 利用 word_cloud 库&#xff0c;将文本文件转为词云图更完整、丰富的示例项目见 GitHub - AlionSSS/wordcloud-webui: The web UI for word_cloud(text t…

Python脚手架系列-PyQt5

记录PyQt模块使用中的一些常常复用的代码 其他 导入界面 import sysfrom PyQt5.QtGui import QIcon from PyQt5.QtWidgets import QApplication, QMainWindow from UI.MainWindow import Ui_MainWindow # 导入UI界面的类以供继承class MyApp(QMainWindow, Ui_MainWindow):de…

网络数据库后端面试题

接着上期 8&#xff0c;索引是怎么提高查询效率的&#xff0c;是不是多越好 索引是数据库中用来提高查询效率的技术&#xff0c;类似目录。如果不使用索引&#xff0c;数据会零散的保存在磁盘中&#xff0c;查询数据需要挨个遍历每一个磁盘块&#xff0c;直到找到数据&#…

未来以来!鸿蒙生态爆发式增长,程序员新出路火速Get。

鸿蒙生态取得爆发式增长&#xff01; 鸿蒙生态建设速度突飞猛进&#xff0c;不仅有超4000款应用加速开发&#xff0c;众多头部SDK伙伴也在积极加入&#xff0c;为开发者提供构建鸿蒙原生应用所需的多项能力。近期&#xff0c;友盟移动统计SDK、神策数据SDK、阿里云日志服务SDK…

【Vue】v-bind对样式控制的增强-操作class

文章目录 一、语法二、示例代码三、京东秒杀-tab栏切换导航高亮四、v-bind对有样式控制的增强-操作style五、进度条案例 为了方便开发者进行样式控制&#xff0c; Vue 扩展了 v-bind 的语法&#xff0c;可以针对 class 类名 和 style 行内样式 进行控制 。 一、语法 语法 &l…

Latex中标注通讯作者

** 直接使用脚注&#xff0c;不用添加宏包 多个同地址的并列&#xff0c;建议加点空格&#xff0c;好看一些 ** \title{xxxxxxxxxxxxxxxxxxx}\author{xxxxxxxxxxxxxxxxxxx\footnote{Corresponding author} ,bbbbbbbbbbbbbbbbbbb}\address{xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx…

免费,Scratch蓝桥杯比赛历年真题--第15届蓝桥杯STEMA真题-2024年3月份(含答案解析和代码)

第15届蓝桥杯STEMA真题-2024年3月份 一、单选题 答案&#xff1a;D 解析&#xff1a;y坐标正值表示上&#xff0c;负值表示下&#xff0c;故答案为D。 答案&#xff1a;C 解析&#xff1a;18<25为真&#xff0c;或关系表示一真即为真&#xff0c;故答案为C。 答案&#xff…

Android设备获取OAID调研和实现

什么是OAID、AAID、VAID OAID OAID是"Android ID"&#xff08;安卓ID&#xff09;的一种替代方案&#xff0c;其全称为"Open Anonymous Identifier"&#xff08;开放匿名标识符&#xff09;。 因传统的移动终端设备标识如国际移动设备识别码&#xff08;…

冯喜运:6.5黄金原油今日行情趋势分析及操作策略

【黄金消息面分析】&#xff1a;在全球经济的波动中&#xff0c;美元和黄金市场的表现一直是投资者关注的焦点。最近&#xff0c;市场情绪和经济数据的波动对这两个市场产生了显著的影响。周二欧市早盘&#xff0c;现货黄金价格出现短线回调&#xff0c;金价跌破2340美元/盎司&…

数组中的第K个最大元素 ---- 分治-快排

题目链接 题目: 分析: 这道题很明显是一个top-K问题, 我们很容易想到用堆排序来解决, 堆排序的时间复杂度是O(N*logN), 不符合题意, 所以我们可以用另一种方法:快速选择算法, 他的时间复杂度为O(N)快速选择算法, 其实是基于快排, 进行修改而成, 我们还是使用将"将数组分…

Mode Solver ------- Mesh size 对仿真结果的影响

Mesh size 对仿真结果的影响 引言正文引言 在 FDE Solver ------ Straight Si waveguide simulation 硅直波导仿真(完美版) 一文中我们介绍了硅直波导的仿真。在 DE Solver ------ Simulation mesh settings 仿真网格设定(完美版) 一文中我们介绍如何设定仿真网格,在 Lum…

【Godot4自学手册】第四十一节背包系统(一)UI设置

各位同学&#xff0c;好久没有更新笔记了&#xff0c;今天开始&#xff0c;我准备自学背包系统。今天先学习下UI界面设置。 一、新建场景和结点 1.新建Node2D场景&#xff0c;命名为Inventory&#xff0c;保存到Scenes目录下&#xff0c;inventory.tscn。 2.新建TextureRect子…

kivy.garden.matplotlib

matplotlib 是什么 # pip install matplotlib2.2.2 from kivy.garden.matplotlib.backend_kivyagg import FigureCanvasKivyAgg FigureCanvasKivyAgg class FigureCanvasKivyAgg(FigureCanvasKivy, FigureCanvasAgg):FigureCanvasKivyAgg class. See module documentation f…

力扣题解 >>> 二叉树

验证二叉搜索树 递归判断数组是否升序 var isValidBST function(root) {// 搜索二叉树中序遍历之后的结果数组一定是升序if(!root){return true;}let result [];var dg function(node){if(node){dg(node.left);result.push(node.val);dg(node.right);}}dg(root);for(let i…

国联易安:网络反不正当竞争,要防患于未然

据市场监管总局官网消息&#xff0c;为预防和制止网络不正当竞争&#xff0c;维护公平竞争的市场秩序&#xff0c;鼓励创新&#xff0c;保护经营者和消费者的合法权益&#xff0c;促进数字经济规范健康持续发展&#xff0c;市场监管总局近日发布《网络反不正当竞争暂行规定》&a…

微信小程序-WXS脚本

一、概述 1.WXS WXS(WeiXin Script)是小程序独有的一套脚本语言&#xff0c;结合 WXML&#xff0c;可以构建出页面的结构。 2.wxs 的应用场景 wxml中无法调用在页面的.js 中定义的函数&#xff0c;但是&#xff0c;wxml 中可以调用 wxs 中定义的函数。因此&#xff0c;小程序…

Jupyter 各种主题

安装和更新主题 # 安装jupyter主题 pip install jupyterthemes # 加载可用主题列表 jt -l可用主题列表 Available Themes:chesterishgrade3gruvboxdgruvboxlmonokaioceans16onedorksolarizeddsolarizedl# 选择你想要的主题 jt -t <name of the theme> # 如 jt -t che…

软件测试总结基础

软件测试总结基础 1. 何为软件测试 定义&#xff1a;使用技术手段验证软件是否满足需求 目的&#xff1a;减少bug&#xff0c;保证质量 2. 软件测试分类 阶段划分 单元测试&#xff0c;针对源代码进行测试集成测试&#xff0c;针对接口进行测试系统测试&#xff0c;针对功能…

Web 网页性能优化

Web 网页性能及性能优化 一、Web 性能 Web 性能是 Web 开发的一个重要方面&#xff0c;侧重于网页加载速度以及对用户输入的响应速度 通过优化网站来改善性能&#xff0c;可以在为用户提供更好的体验 网页性能既广泛又非常深入 1. 为什么性能这么重要&#xff1f; 1. 性能…