OJ万题详解––木板上的蚂蚁(C++详解)

news2025/1/1 21:43:52

题目

题目描述

有一块木板,长度为 n 个 单位 。一些蚂蚁在木板上移动,每只蚂蚁都以 每秒一个单位 的速度移动。其中,一部分蚂蚁向 左 移动,其他蚂蚁向 右 移动。

当两只向 不同 方向移动的蚂蚁在某个点相遇时,它们会同时改变移动方向并继续移动。假设更改方向不会花费任何额外时间。

而当蚂蚁在某一时刻 t 到达木板的一端时,它立即从木板上掉下来。

给你一个整数 n 和两个整数数组 left 以及 right 。两个数组分别标识向左或者向右移动的蚂蚁在 t = 0 时的位置。请你返回最后一只蚂蚁从木板上掉下来的时刻。

输入格式

第一行输入三个正整数n,a,b,分别表示木板的长度,初始向左移动蚂蚁的数量和向右移动蚂蚁的数量

第二行输入a个空格分开的非负整数,分别表示向左移动蚂蚁的初始位置

第二行输入b个空格分开的非负整数,分别表示向右移动蚂蚁的初始位置

输出格式

输出只有一个整数,表示最后一只蚂蚁从木板上掉下来的时刻。

 

样例

样例输入 1

4 2 2
4 3
1 0

样例输出 1

4

样例解释 1

如上图所示:

-下标 0 处的蚂蚁命名为 A 并向右移动。

-下标 1 处的蚂蚁命名为 B 并向右移动。

-下标 3 处的蚂蚁命名为 C 并向左移动。

-下标 4 处的蚂蚁命名为 D 并向左移动。

请注意,蚂蚁在木板上的最后时刻是 t = 4 秒,之后蚂蚁立即从木板上掉下来。(也就是说在 t = 4.0000000001 时,木板上没有蚂蚁)。

样例输入 2

7 0 8
0 1 2 3 4 5 6 7

样例输出 2

7

样例解释 2

所有蚂蚁都向右移动,下标为 0 的蚂蚁需要 7 秒才能从木板上掉落。

样例输入 3

7 8 0
0 1 2 3 4 5 6 7

样例输出 3

7

样例解释 3

所有蚂蚁都向左移动,下标为 7 的蚂蚁需要 7 秒才能从木板上掉落。

样例输入 4

9 1 1
5
4

样例输出 4

复制5

样例解释 4

t = 1 秒时,两只蚂蚁将回到初始位置,但移动方向与之前相反。

数据范围与提示

数据范围:

1 <= n <= 10^4

0 <= a <= n + 1

0 <= left[i] <= n

0 <=b <= n + 1

0 <= right[i] <= n

1 <= a + b <= n + 1

left 和 right 中的所有值都是唯一的,并且每个值只能出现在二者之一 中。

分析

这道题看似很绕,蚂蚁不停地往返往返,光看着样例解释就让人头晕眼花。

但是这一道题实则不难,我们通过数学思想可以得知,如果两只蚂蚁相遇了,就不用讨论他们何时相遇,只用把他们的身份互换了就行了,有了这个思路,我们很快就能知道,花费的时间最大其实就是要走的距离最大,就只要算出蚂蚁距离端点的最大值就行了

for(int i=1;i<=l;i++){
    cin>>a[i];
    maxl=maxl<a[i]?a[i]:maxl;
}

这一块代码是计算往左走蚂蚁的最大值。

for(int i=1;i<=r;i++){
    cin>>b[i];
    maxr=maxr<s-b[i]?s-b[i]:maxr;
}

 这一块就是计算向右走蚂蚁的 最大值。

然后接着输出就可以了

接下来就是参考代码

参考代码

#include<bits/stdc++.h>
using namespace std;
long long s,l,r,maxl=INT_MIN;
long long maxr=INT_MIN,a[10005],b[10005];
int main(){
	ios::sync_with_stdio(false);
	cin.tie(0),cout.tie(0);
	cin>>s>>l>>r;
	for(int i=1;i<=l;i++){
		cin>>a[i];
		maxl=maxl<a[i]?a[i]:maxl;
	}
	for(int i=1;i<=r;i++){
		cin>>b[i];
		maxr=maxr<s-b[i]?s-b[i]:maxr;
	}
	cout<<max(maxr,maxl)<<endl;
	return 0;
}

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

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

相关文章

MongoDB 数据库操作

场景&#xff1a; 已知广告点击数据的记录已经存在&#xff0c;数据统计在mongodb中&#xff0c;现在要统计广告列表pv和uv。 思路&#xff1a; 这个时候就想到mysql的聚合查询group、count、distinct&#xff0c;但是于是就找了好多文档&#xff0c;发现mongodb的语法和mys…

“易”起涨知识|一文告诉你数字化生产的优势

在信息化高速发展的时代&#xff0c;企业工厂的数字化转型已经不是想不想转的问题&#xff0c;而是必须得转的形势。 智慧工厂是现代工厂信息化发展的新阶段。是在数字化工厂的基础上&#xff0c;利用物联网的技术和设备监控技术加强信息管理和服务&#xff1b;清楚掌握产销流…

Dart语法学习-变量

一、 创建Dart File Hello, World void main() {print(Hello world); }Log: Hello world 二、变量 1.Dart 支持类型推断。 var name Voyager I;var year 1977;var antennaDiameter 3.7;var flybyObjects [A1, A2, A3, A4];var image {tags:[saturn],url:www.baidu,com};…

王道操作系统笔记(四)———— 进程同步与互斥

文章目录一、同步与互斥的概念1.1 同步与互斥的基本概念1.2 临界资源与共享资源1.3 独占设备与共享设备二、实现临界区互斥的基本方法2.1 软件实现方法2.1.1 单标志法2.1.2 双标志先检查法2.1.3 双标志后检查法2.1.4 Peterson 算法2.1.5 软件实现方法总结2.2 硬件实现方法2.2.1…

【电子通识】查找硬件学习资料的方法

做为一名硬件工程师&#xff0c;在工作中会经常遇到一些问题&#xff0c;这些问题最开始可能也并不知道是什么原因。对于这些异常现象&#xff0c;我们可能需要深入去了解电路原理或器件特性等方式&#xff0c;从原理上理解并解决。当再次遇到相同或相似的问题时&#xff0c;我…

Python爬虫2--数据解析方法:bs4库的使用和案例

目录标题数据解析1、BeautifulSoup库1.1 BeautifulSoup库入门1.1.1 BeautifulSoup类的基本元素&#xff1a;1.1.2 基于bs4库的HTML内容遍历方法1.1.3 基于bs4库的HTML格式化和编码1.2 信息组织和提取方法1.2.1 信息标记的三种形式&#xff1a;xml,json,yaml1.2.2 三种信息标记形…

360数据恢复如何操作?360安全卫士恢复误删文件的方法(详解)

3 60安全 卫士属于一款杀毒软件&#xff0c;这是很多人都知道的事情。但是你知道吗&#xff1f;3 60安全 卫士还有一个免费功能&#xff0c;就是文件恢复功能。 当文件被误删&#xff0c;电脑回收站又找不到&#xff0c;你可以尝试通过3 60里面的文件恢复功能来进行数据恢复。…

Leetcode:62. 不同路径、63. 不同路径 II(C++)

目录 62. 不同路径 问题描述&#xff1a; 实现代码与解析&#xff1a; 深度优先&#xff08;超时&#xff09;&#xff1a; 原理思路&#xff1a; 动态规划&#xff1a; 原理思路&#xff1a; 数学方法&#xff1a; 原理思路&#xff1a; 63. 不同路径 II 问题描述&…

AcWing蓝桥杯AB组辅导课09、复杂DP

文章目录前言一、复杂DP例题例题1&#xff1a;AcWing 1050. 鸣人的影分身&#xff08;线性dp&#xff09;分析题解&#xff1a;DP例题2&#xff1a;AcWing 1047. 糖果&#xff08;背包问题变形&#xff09;分析题解&#xff1a;DP&#xff08;01背包问题变形&#xff09;例题3&…

静态库与动态库的生成与使用

一、库文件 预编译——>编译——>汇编——>链接&#xff08;使用库&#xff09;——>可执行文件 二、生成库&#xff1a;把大量的已经实现的代码打包起来 生成动态库&#xff1a; 1、将源码遍历汇编生成二进制指令 gcc -fPIC -c child.c -o child.o 2、将所有二进…

即时通讯开发之详解TCP/IP中的UDP 协议

UDP 是传输层协议,和 TCP 协议处于一个分层中,但是与 TCP 协议不同,UDP 协议并不提供超时重传,出错重传等功能,也就是说其是不可靠的协议。UDP 协议头2.1UDP 端口号由于很多软件需要用到 UDP 协议,所以 UDP 协议必须通过某个标志用以区分不同的程序所需要的数据包。端口号的功能…

C 语言零基础入门教程(二十一)

C 头文件 头文件是扩展名为 .h 的文件&#xff0c;包含了 C 函数声明和宏定义&#xff0c;被多个源文件中引用共享。有两种类型的头文件&#xff1a;程序员编写的头文件和编译器自带的头文件。 在程序中要使用头文件&#xff0c;需要使用 C 预处理指令 #include 来引用它。前…

Linux | 编辑器gcc/g++的使用【动静态库的认识】

文章目录一、对程序的认知 && 初识gcc1、程序是如何诞生的&#xff1f;2、gcc的初步认识3、如何使用gcc二、gcc逐步分析程序的翻译环境1、预编译【进行宏替换】2、编译【C语言——>汇编语言】3、汇编【汇编语言——>可重定位目标二进制文件】4、链接【生成可执行…

一篇文章学会写SQL

本篇文章主要讲如何写SQL&#xff0c;虽然我在之前有篇文章中写到过数据库的操作和概念&#xff0c;其中有讲到数据库和表的操作语句以及有哪些函数和查询关键字&#xff08;本篇不赘述&#xff09;&#xff0c;但毕竟理解概念和会实践书写是两码事。。 身为一名测试人员&#…

证明:lim (x->0+) x^x=1

原式&#xff1a;lim⁡x→0xx\lim _{x\to 0^{}} {x^{x}}x→0lim​xx 根据公式1:u(x)v(x)eu(x)ln⁡v(x)u(x)^{v(x)}e^{u(x)\ln v(x)}u(x)v(x)eu(x)lnv(x)则原式可以化为lim⁡x→0exln⁡x\lim _{x\to 0^{}} e^{x \ln x}x→0lim​exlnx 接下来利用倒代换进行进一步计算。&#xff…

【USB】USB video class (UVC)相关概念学习

UVC协议 IAD 全称Interface Association Descriptor This is used to describe that two or more interfaces are associated to the same function. An ‘association’ includes two or more interfaces and all of their alternate setting interfaces. IAD用来描述由两个…

一次JVM垃圾收集全过程

目录 JVM堆内存分配 JVM垃圾收集完整过程&#xff08;带图解&#xff09; 在介绍垃圾收集过程之前&#xff0c;有必要先对JVM堆内存做一个回顾&#xff0c;因为讲垃圾收集主要针对的是堆内存。 JVM堆内存分配 在JDK1.8之前&#xff0c;JVM堆内存主要分为新生代、老年代和永…

Kafka和Flink双剑合璧,Confluent收购Immerok引起业内广泛讨论

2023年开年开源界就出了一个大新闻&#xff0c;1月6日Kafka的商业化公司Confluent创始人宣布签署了收购 Immerok 的最终协议&#xff0c;而Immerok是一家为 Apache Flink 提供完全托管服务的初创公司&#xff0c;其创始团队正是Flink的创始团队。 无论是Kafka还是Flink&#x…

MQ 消息丢失、重复、积压问题,如何解决?

引入 MQ 消息中间件最直接的目的是&#xff1a;做系统解耦合流量控制&#xff0c;追其根源还是为了解决互联网系统的高可用和高性能问题。 系统解耦&#xff1a;用 MQ 消息队列&#xff0c;可以隔离系统上下游环境变化带来的不稳定因素&#xff0c;比如京豆服务的系统需求无论如…

你安全吗?丨生活中常见的黑产行为有哪

作者丨黑蛋电视剧《你安全吗&#xff1f;》我也追完了&#xff0c;到了终结篇。在结尾&#xff0c;网安黑产头子马平川终于因为陷害秦淮攻击虎迫系统被查出来就是虎迫内奸&#xff0c;随后也被一系列证据指出饮料厂等薅羊毛事件背后都有马平川的影子&#xff1a;今天我们就来聊…