当前位置: 首页 > news >正文

codeforces B2. The Strict Teacher

目录

题目

思路简述:

总代码:


题目

B1. 严厉的老师(困难版)
每个测试用例时间限制:1.5 秒
每个测试用例内存限制:256 兆字节

纳雷克和措索瓦克忙着准备这一轮(活动),所以他们没来得及完成作业,于是决定抄袭大卫的作业。他们严厉的老师发现大卫没有作业,现在想惩罚他。她雇了其他老师来帮她抓住大卫。现在有 m 位老师一起在追他。幸运的是,教室很大,所以大卫有很多地方可以躲藏。

教室可以表示成一条一维直线,上面的格子从 1 到 n 编号(包含 1 和 n )。

一开始,所有 m 位老师和大卫都在不同的格子里。然后他们开始移动。在每一轮移动中:

大卫可以移动到相邻的格子,或者停留在当前格子。
然后,每位老师同时移动到相邻的格子,或者停留在当前格子。

这个过程会一直持续,直到大卫被抓住。当有任意一位老师(可能不止一位)和大卫处于同一个格子时,大卫就被抓住了。每个人都能看到其他人的移动,所以他们都会采取最优策略行动。

你的任务是找出在所有人都采取最优策略的情况下,老师们抓住大卫需要多少轮移动。

采取最优策略意味着学生以一种能让老师抓住他所需移动轮数最大化的方式移动;而老师们相互配合,以一种能让抓住学生所需移动轮数最小化的方式移动。

此外,由于纳雷克和措索瓦克认为这个任务很简单,他们决定针对大卫的位置给出 q 次询问。注意:这是简单版本,你只会得到一次询问。
输入
输入的第一行包含一个整数 t(1 ≤ t ≤ 10⁵),表示测试用例的数量。接下来是每个测试用例的描述。

每个测试用例的第一行包含三个整数 n、m 和 q(3 ≤ n ≤ 10⁹,m = 2,q = 1),分别表示直线上格子的数量、老师的数量和询问的数量。

每个测试用例的第二行包含 m 个不同的整数 b₁, b₂, …, bₘ(1 ≤ bᵢ ≤ n),表示老师们所在的格子编号。

每个测试用例的第三行包含 q 个整数 a₁, a₂, …, a_q(1 ≤ aᵢ ≤ n),表示每次询问时大卫所在的格子编号。

可以保证,对于任意的 i、j,满足 1 ≤ i ≤ m 且 1 ≤ j ≤ q 时,bᵢ ≠ aⱼ 。
输出
对于每个测试用例,输出 q 行,其中第 i 行包含第 i 次询问的答案。


说明
在第一个例子中,学生可以就待在 2 号格子。最初在 1 号格子的老师移动一步就能到达 2 号格子。因此,答案是 1。
在第二个例子中,学生应该就待在 1 号格子。最初在 3 号格子的老师移动两步就能到达 1 号格子。因此,答案是 2。

思路简述:

如果学生在所有老师左边,直接让学生去最左边,然后等着被抓

如果学生在所有老师右边,直接让学生去最右边,然后等着被抓

如果学生在老师中间,找到距离学生最近的两个老师,让学生去这两个老师的中间,然后等着被抓

总代码:

#include<bits/stdc++.h>
using namespace std;
const int N=1e5+10;
int a[N],q;
void solve()
{int n,m,k;cin >> n >> m >> k;for(int i=1;i<=m;i++)cin >> a[i];sort(a+1,a+1+m);int mn=a[1],mx=a[m];while(k--){int c;cin >> c;if(c<mn)//学生在所有老师左边{cout << mn-1<<endl;}else if(c>mx)//学生在所有老师右边{cout << n-mx<<endl;}else//学生被老师包夹,二分查找距离学生最近的两个老师的坐标{int l=1,r=m;while(l+1!=r){int mid=l+r>>1;if(a[mid]>c)r=mid;else l=mid;}cout << (a[r]-a[l])/2<<endl;}}
}
int main()
{int q;cin >> q;while(q--){solve();}
}

相关文章:

codeforces B2. The Strict Teacher

目录 题目 思路简述&#xff1a; 总代码&#xff1a; 题目 B1. 严厉的老师&#xff08;困难版&#xff09; 每个测试用例时间限制&#xff1a;1.5 秒 每个测试用例内存限制&#xff1a;256 兆字节 纳雷克和措索瓦克忙着准备这一轮&#xff08;活动&#xff09;&#xff0c;…...

Linux:35.其他IPC和IPC原理+信号量入门

通过命名管道队共享内存的数据发送进行保护的bug&#xff1a; 命名管道挂掉后&#xff0c;进程也挂掉了。 6.systemV消息队列 原理:进程间IPC:原理->看到同一份资源->维护成为一个队列。 过程&#xff1a; 进程A,进程B进行通信。 让操作系统提供一个队列结构&#xff0c;…...

docker测试镜像源

参考文章 https://zhuanlan.zhihu.com/p/28662850275 格式如下&#xff1a;&#xff08;不要加上前缀https://&#xff09; sudo docker pull镜像源地址/要拉取的镜像名 和pip、npm不同&#xff0c; unknown flag: --registry-mirror 这个参数可能不存在。...

AdamW 是 Adam 优化算法的改进版本; warmup_steps:学习率热身的步数

AdamW 是 Adam 优化算法的改进版本 目录 AdamW 是 Adam 优化算法的改进版本1. `optimizer = torch.optim.AdamW(model.parameters(), lr=2e-4)`2. `num_epochs = 11`3. `total_steps = len(dataloader) * num_epochs`warmup_steps:学习率热身的步数,学习率会从一个较小的值逐…...

Java从入门到“放弃”(精通)之旅——运算符③

&#x1f31f;Java从入门到“放弃”&#xff08;精通&#xff09;之旅&#x1f680;&#xff1a;运算符深度解析 引言&#xff1a;运算符的本质与价值 作为Java语言的核心组成部分&#xff0c;运算符是构建程序逻辑的基础元素。它们不仅仅是简单的数学符号&#xff0c;更是程…...

关于 微服务负载均衡 的详细说明,涵盖主流框架/解决方案的对比、核心功能、配置示例及总结表格

以下是关于 微服务负载均衡 的详细说明&#xff0c;涵盖主流框架/解决方案的对比、核心功能、配置示例及总结表格&#xff1a; 1. 负载均衡的核心概念 负载均衡在微服务中用于将请求分发到多个服务实例&#xff0c;以实现&#xff1a; 高可用性&#xff1a;避免单点故障。性…...

【AI提示词】API开发专家

提示说明 API开发专家专注于设计和实现高效、稳定、安全的应用程序接口&#xff08;API&#xff09;。他们通过深入理解业务需求和用户场景&#xff0c;为用户提供定制化的API解决方案。 提示词 # 角色 API开发专家## 注意 1. 专家设计应考虑API开发过程中的技术细节和用户需…...

Node.js中http模块详解

Node.js 中 http 模块全部 API 详解 Node.js 的 http 模块提供了创建 HTTP 服务器和客户端的功能。以下是 http 模块的所有 API 详解&#xff1a; 1. 创建 HTTP 服务器 const http require(http);// 1. 基本服务器 const server http.createServer((req, res) > {res.w…...

uniapp中,使用plus.io实现安卓端写入文件

这段代码是要删除的&#xff0c;留在这里避免以后用到。 在我写流式语音接收与播放的时候&#xff0c;写到这里无法继续了&#xff0c;因为播放时总是出错&#xff0c;无法播放&#xff0c;因为audioContext.play()不支持 但是&#xff0c;我写的这些&#xff0c;用于写入文件是…...

Linux xorg-server 解析(二)- 如何调试 xorg-server

一:概述 Xorg-server简称Xorg,它是Linux窗口系统的核心组件,它是用户态应用程序,但它的调试方法和普通用户态应用程序有所不同,因为Xorg是系统的核心组件,负责图形显示和输入设备的管理,所以在单台机器上调试Xorg可能会面临一些困难和限制,如果在同一台机器上调试它,可…...

CFS 调度器两种调度类型普通调度 和 组调度

在 Linux 的 CFS&#xff08;Completely Fair Scheduler&#xff09; 调度器中&#xff0c;确实存在两种调度类型&#xff1a;普通调度 和 组调度。这两种调度类型分别适用于不同的场景&#xff0c;并通过三个关键维度&#xff08;权重、抢占优先级、最大配额&#xff09;来影响…...

「逻辑推理」AtCoder AT_abc401_d D - Logical Filling

前言 这次的 D 题出得很好&#xff0c;不仅融合了数学逻辑推理的知识&#xff0c;还有很多细节值得反复思考。虽然通过人数远高于 E&#xff0c;但是通过率甚至不到 60%&#xff0c;可见这些细节正是出题人的侧重点。 题目大意 给定一个长度为 N N N 的字符串 S S S&#…...

PyTorch 深度学习实战(36):混合精度训练与梯度缩放

在上一篇文章中&#xff0c;我们探讨了图生成模型与分子设计。本文将深入介绍混合精度训练&#xff08;Mixed Precision Training&#xff09;和梯度缩放&#xff08;Gradient Scaling&#xff09;技术&#xff0c;这些技术可以显著加速模型训练并减少显存占用&#xff0c;同时…...

【Flink运行时架构】组件构成

在Flink的运行架构中&#xff0c;有两大比较重要的组件&#xff1a;作业管理器&#xff08;JobManager&#xff09;和任务管理器&#xff08;TaskManager&#xff09;。 Flink的作业提交与任务处理时的系统如下图所示。 其中&#xff0c;客户端并不是处理系统的一部分&#xff…...

simpy仿真

一共5个顾客&#xff0c;2个服务台 import simpy import randomdef customer(env, name, service_time_mean):arrival_time env.nowprint(f{arrival_time}: {name} 到达服务台&#xff0c;开始排队)with server.request() as req:yield reqwait_time env.now - arrival_time…...

Docker 安装MySQL

一键启动 docker run -d \--name mysql \-p 3306:3306 \-e TZAsia/Shanghai \-e MYSQL_ROOT_PASSWORD1234 \-v /usr/local/mysql/data:/var/lib/mysql \-v /usr/local/mysql/conf:/etc/mysql/conf.d \--restart always --name mysql \mysql 检查是否启动 docker ps 本地连接测…...

【消息队列kafka_中间件】三、Kafka 打造极致高效的消息处理系统

在当今数字化时代&#xff0c;数据量呈爆炸式增长&#xff0c;实时数据处理的需求变得愈发迫切。Kafka 作为一款高性能、分布式的消息队列系统&#xff0c;在众多企业级应用中得到了广泛应用。然而&#xff0c;要充分发挥 Kafka 的潜力&#xff0c;实现极致高效的消息处理&…...

conda如何安装和运行jupyter

在Conda环境中安装和运行Jupyter Notebook是一项常见且实用的任务&#xff0c;特别是在数据科学和机器学习项目中。以下是使用Conda安装和运行Jupyter Notebook的步骤&#xff1a; 安装Jupyter Notebook 首先&#xff0c;确保你的Conda是最新的。打开终端或Anaconda Prompt&a…...

防爆平板:石油化工厂智慧转型的“中枢神经”

易燃易爆气体、高温高压环境、复杂设备集群&#xff0c;这些特性使得传统电子设备难以直接融入生产流程。而防爆平板的出现&#xff0c;不仅打破了这一技术壁垒&#xff0c;更通过智能化、模块化设计&#xff0c;逐步成为连接人、设备与数据的“中枢神经”&#xff0c;推动石油…...

遨游科普:三防平板可以实现哪些功能?

在现代工业与户外作业场景中&#xff0c;电子设备不仅要面对极端环境的考验&#xff0c;更要承担起高效协同生产的重任。三防平板作为“危、急、特”场景移动终端的代表性产品&#xff0c;其核心价值早已超越传统消费级设备的范畴&#xff0c;成为连接智慧生产与安全管理的重要…...

互联网三高-数据库高并发之分库分表

1 数据库概述 1.1 数据库本身的瓶颈 ① 连接数 MySQL默认最大连接数为100&#xff0c;允许的最大连接数为16384 ② 单表海量数据查询性能 单表最好500w左右&#xff0c;最大警戒线800w ③ 单数据库并发压力问题 MySQL QPS&#xff1a;1500左右/秒 ④ 系统磁盘IO、CPU瓶颈 1.2 数…...

Python----机器学习(基于贝叶斯的鸢尾花分类)

贝叶斯方法是一种统计推断的 方法&#xff0c;它利用贝叶斯定理来更新我们对事件概率的信念。这种方法在机器学习和数据 分析中得到广泛应用&#xff0c;特别是在分类和概率估计问题上。 一、数据集介绍 这是分类方法文献中最早使用的数据集之一&#xff0c;广泛用于统计和机器…...

问题 | 对于初学者来说,esp32和stm32哪个比较适合?

对于初学者选择ESP32还是STM32入门嵌入式开发&#xff0c;需综合考虑学习目标、兴趣方向及未来职业规划。以下是两者的对比分析及建议&#xff1a; 1. 适合初学者的关键因素 ESP32的优势 内置无线通信&#xff1a;集成Wi-Fi和蓝牙功能&#xff0c;无需额外模块即可开发物联网…...

org.apache.spark.SparkException: Kryo serialization failed: Buffer overflow...

Spark异常&#xff1a;Kryo serialization failed: Buffer overflow. 1、问题描述 SparkSQL任务报错如下&#xff1a; org.apache.spark.SparkException: Kryo serialization failed: Buffer overflow. Available: 0, required: xxx. To avoid this, increase spark.kryoseri…...

webpack vite

​ 1、webpack webpack打包工具&#xff08;重点在于配置和使用&#xff0c;原理并不高优。只在开发环境应用&#xff0c;不在线上环境运行&#xff09;&#xff0c;压缩整合代码&#xff0c;让网页加载更快。 前端代码为什么要进行构建和打包&#xff1f; 体积更好&#x…...

论文笔记——KIMI-VL:具有增强推理能力的有效开源视觉语言模型

KIMI-VL&#xff1a;具有增强推理能力的有效开源视觉语言模型 原文地址&#xff1a;https://arxiv.org/pdf/2504.07491v1 开源地址&#xff1a;https://github.com/MoonshotAI/Kimi-VL 目录 简介架构概述训练方法主要功能性能基准通过长链思考增强推理应用结论 简介 视觉…...

大模型蒸馏-小模型超进化

&#x1f44f;作者简介&#xff1a;大家好&#xff0c;我是爱吃芝士的土豆倪&#xff0c;24届校招生Java选手&#xff0c;很高兴认识大家&#x1f4d5;系列专栏&#xff1a;Spring原理、JUC原理、Kafka原理、分布式技术原理、数据库技术、JVM原理、AI应用&#x1f525;如果感觉…...

辅助记忆数字和唱名的小工具【仅PC端】

通过网盘分享的文件&#xff1a;random_music_note.exe 链接: https://pan.baidu.com/s/1Akc2gPzAcyhEfPHlbOYLXw?pwd4fua 提取码: 4fua –来自百度网盘超级会员v7的分享...

Android 知识沉淀

注解 1.枚举类型传参优化 enum WeekDay{SUNDAY, MONDAY}public static void setDay(WeekDay day){}我们已知&#xff0c;枚举类型是一个对象&#xff0c;对象占用的空间较大&#xff0c;有 12 个对象头对象的数据部分8 字节对齐&#xff0c;所以这里可以利用注解优化&#xff…...

KiActivateWaiterQueue函数和Queue->Header.WaitListHead队列等待列表的关系

第一部分&#xff1a; if (Thread->ApcState.KernelApcPending && (Thread->SpecialApcDisable 0) && (Thread->WaitIrql < APC_LEVEL)) { } else { // // Insert wait block in ob…...

代码学习总结(一)

代码学习总结&#xff08;一&#xff09; 这个系列的博客是记录下自己学习代码的历程&#xff0c;有来自平台上的&#xff0c;有来自笔试题回忆的&#xff0c;主要基于 C 语言&#xff0c;包括题目内容&#xff0c;代码实现&#xff0c;思路&#xff0c;并会注明题目难度&…...

设计模式 --- 策略模式

​策略模式&#xff08;Strategy Pattern&#xff09;是一种 ​​行为型设计模式​​&#xff0c;用于动态切换算法或策略​​&#xff0c;使得算法可以独立于客户端变化。它通过封装算法策略并使其可互换&#xff0c;提升了系统的灵活性和扩展性&#xff0c;尤其适用于需要多种…...

c++进阶之----智能指针

1.概念 在 C 中&#xff0c;智能指针是一种特殊的指针类型&#xff0c;它封装了裸指针&#xff08;raw pointer&#xff09;的行为&#xff0c;并通过 RAII&#xff08;Resource Acquisition Is Initialization&#xff0c;资源获取即初始化&#xff09;机制自动管理动态分配的…...

08-JVM 面试题-mk

1.JVM 的各部分组成 知道JVM 的好处:知道java 运行机制,排查问题的能力增加,比如内存泄漏、CPU飙高 JVM 是什么:Java Virtual Machine缩写,Java程序的运行环境(java二进制字节码的运行环境) 好处: 一次编写,到处运行自动内存管理,垃圾回收机制从图中可以看出 JVM …...

MTK7628基于原厂的mtk-openwrt-sdk-20160324-8f8e4f1e.tar.bz2 源代码包,配置成单网口模式的方法

一、配置. 在SDK工程下&#xff0c;运行make kernel_menuconfig&#xff0c;如下图所示&#xff1a; Ralink Module --->选上“One Port Only”&#xff0c;如下图所示&#xff1a; 如果P0网口实现WAN口&#xff0c;就配置成W/LLLL,否则就配置成LLLL/W. 二、修改网口的原代…...

青少年编程与数学 02-016 Python数据结构与算法 15课题、字符串匹配

青少年编程与数学 02-016 Python数据结构与算法 15课题、字符串匹配 一、字符串匹配问题的基本概念&#xff08;一&#xff09;定义&#xff08;二&#xff09;术语 二、暴力匹配算法&#xff08;Naive String Matching&#xff09;&#xff08;一&#xff09;算法逻辑&#xf…...

基础层数据从kafka读取写入hbase的优化方案

背景: 上游kafka的topic只有一个分区,所以spark在消费的时候,无论设置的executor数有多少,最终只有一个executor在执行,如果不指定executor num的话,默认是开启两个executor,有一个executor的资源是浪费的,例如下面显示的情况,其实只有一个executor是active的状态. 在消费的时…...

thingsboard3.9.1编译问题处理

问题1&#xff1a; [ERROR] Failed to execute goal org.thingsboard:gradle-maven-plugin:1.0.12:invoke (default) on project http: Execution default of goal org.thingsboard:gradle-maven-plugin:1.0.12:invoke failed: Plugin org.thingsboard:gradle-maven-plugin:1.…...

Adobe Photoshop 2025 Mac中文 Ps图像编辑

Adobe Photoshop 2025 Mac中文 Ps图像编辑 一、介绍 Adobe Photoshop 2025 Mac版集成了多种强大的图像编辑、处理和创作功能。①强化了Adobe Sensei AI的应用&#xff0c;通过智能抠图、自动修复、图像生成等功能&#xff0c;用户能够快速而精确地编辑图像。②3D编辑和动画功…...

什么是VLA

视觉-语言-动作&#xff08;VLA&#xff09;技术综述&#xff1a;迈向具身智能的未来 1. 引言 随着人工智能从单一模态感知迈向多模态交互&#xff0c;视觉-语言-动作&#xff08;Vision-Language-Action, VLA&#xff09; 技术逐渐成为连接感知、推理与物理行动的核心桥梁。V…...

数据结构:C语言版严蔚敏和解析介绍,附pdf

《数据结构&#xff1a;C语言版&#xff08;第2版&#xff09;》严蔚敏李冬梅吴伟民.pdf 《数据结构&#xff1a;C语言版》严蔚敏&#xff0c;李冬梅.pdf 《数据结构C语言第2版习题解析与实验指导》李冬梅.pdf 「《数据结构&#xff1a;C语言版&#xff08;第2版 &#xff09;》…...

C++线段树详解与实现技巧

📚 C++线段树详解与实现技巧 线段树(Segment Tree)是一种高效处理 区间查询 和 区间更新 的数据结构,时间复杂度为 O(log n)。本文结合代码实例,详解其核心原理与实现细节。 🌳 线段树结构特点 完全二叉树:使用数组存储,父子节点关系通过下标计算。区间划分:每个节…...

202527 | RabbitMQ-基础 | 队列 | Direct + Fanout + Topic 交换机 | 消息转换器

RabbitMQ RabbitMQ 架构与核心概念详解 一、整体架构图 #mermaid-svg-UTlKmvHL7RNWK6vu {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-UTlKmvHL7RNWK6vu .error-icon{fill:#552222;}#mermaid-svg-UTlKmvHL7RNWK6v…...

【学习笔记】服务器上使用 nbconvert 将 Jupyter Notebook 转换为 PDF

1. 环境准备&#xff1a;安装必要工具 在服务器终端运行以下命令&#xff0c;确保依赖已安装&#xff1a; (1) 安装 nbconvert 和 pandoc pip install nbconvert pandoc (2) 安装 LaTeX&#xff08;推荐 TeX Live&#xff09; # Ubuntu/Debian sudo apt-get update sudo a…...

List、Set集合通过Stream流求和

目录 一、泛型为Integer、Long、Double、BigDecimal求和 二、泛型为实体类 对单个属性求和 对多个属性分别分组求和 并返回聚合后的对象 多字段乘积求和&#xff08;基本数据类型&#xff09; 多字段乘积求和&#xff08;BigDecimal&#xff09; 对对象中的多个字段求和…...

微软VSCode 能否击败 Cursor 和 Windsurf?

微软是否能利用平台优势和许可限制来阻止竞争对手? AI 代码编辑器之战加剧 蓬勃发展的 AI 代码编辑领域竞争日益激烈,这个最具变革性和盈利性的新技术领域正在适应相互间的竞争。Visual Studio Code 目前是最主导的代码编辑器。 “根据 Stack Overflow 调查,Visual Studi…...

VSCode会击败Cursor和Windsurf吗?

VSCode 会击败 Cursor 和 Windsurf 吗&#xff1f;微软能不能靠自己的地盘优势和规则限制打压对手&#xff1f;答案是"能"&#xff0c;但他们真的会这么干吗&#xff1f; Cursor & Windsurf vs VSCode Copilot 大PKAI编程工具大战越来越激烈现在最火最赚钱的AI…...

机器学习(4)—— K近邻算法

文章目录 1. K近邻算法&#xff08;K-Nearest Neighbors, KNN&#xff09;原理1.1. K近邻算法是什么算法&#xff1f;1.2. 核心思想 2. K近邻算法的步骤2.1. 选择K值2.2. 计算距离2.3. 选择最近邻&#xff1a;2.4. 做出预测&#xff1a; 3. K值的选择4. 数据标准化5. 优缺点6. …...

深入解读 React 纯组件(PureComponent)

什么是纯组件&#xff1f; React 的纯组件(PureComponent)是 React.Component 的一个变体&#xff0c;它通过浅比较(shallow comparison)props 和 state 来自动实现 shouldComponentUpdate() 方法&#xff0c;从而优化性能。 核心特点 1. 自动浅比较&#xff1a; PureCompon…...

常见MQ及类MQ对比:Redis Stream、Redis Pub/Sub、RocketMQ、Kafka 和 RabbitMQ

常见MQ及类MQ对比 基于Grok调研 Redis Stream、Redis Pub/Sub、RocketMQ、Kafka 和 RabbitMQ 关键点&#xff1a; Redis Pub/Sub 适合简单实时消息&#xff0c;但不持久化&#xff0c;消息可能丢失。Redis Stream 提供持久化&#xff0c;适合需要消息历史的场景&#xff0c;但…...