题目 3298: 蓝桥杯2024年第十五届决赛真题-兔子集结

news2025/6/2 8:07:50

题目 3298: 蓝桥杯2024年第十五届决赛真题-兔子集结
时间限制: 2s 内存限制: 192MB 提交: 2499 解决: 309
题目描述
    在森林幽静的一隅,有一村落居住着 n 只兔子。

    某个月光皎洁的夜晚,这些兔子列成一队,准备开始一场集结跳跃活动。村落中的每只兔子都占据一个位置,对于第 i 只兔子,其位置为 pi 。我们称位置较小的为左边,位置较大的为右边。

    按照兔子村落的习俗,每只兔子都会选择距离自己最近的兔子作为同伴,并向同伴所在的方向进行跳跃。如果一只兔子左边和右边的兔子距离它一样近,那么它会选择左边的兔子作为同伴。

    兔子的每次跳跃,只能向左或向右移动一个单位距离。也就是说,如果一只兔子当前位于 x 的位置,那么它下一次跳跃后会到达 x − 1 或者 x + 1 的位置。

当两只相互靠近的兔子之间的距离为 1 时,左边的兔子会停在原地,而右边的兔子会跳到左边兔子的位置上,完成集结。

    兔子们会一直跳跃,直到与自己最初选择的同伴完成集结后停下。

    请问,当所有兔子都完成集结后,每只兔子都分别位于哪个位置上?

输入格式
输入的第一行包含一个整数 n,表示兔子的数量。

第二行包含 n 个整数 p1, p2, · · · , pn ,相邻整数之间使用一个空格分隔,表示每只兔子的初始位置。

输出格式
输出一行包含 n 个整数,表示每只兔子完成集结后的位置。

样例输入复制
5
2 5 7 9 1
样例输出复制
1 6 6 6 1
提示
【样例说明】   

 兔子 1 选择的同伴为兔子 5,兔子 5 选择的同伴为兔子 1。由于它们彼此间的距离为 1,因此兔子 5 会停在原地,而兔子 1 会跳到位置 1 上,与兔子 5完成集结。

    兔子 2 选择的同伴为兔子 3,兔子 4 选择的同伴也为兔子 3。对于兔子 3来说,兔子 2 和兔子 4 与它的距离相同,所以它会选择左边的兔子 2 作为同伴。兔子 2 会向右跳一个位置,兔子 3 会向左跳一个位置,兔子 4 会向左跳一个位置。此时,兔子 2 和兔子 3 均位于位置 6,完成集结(停止跳跃)。兔子 4会继续向左跳跃,直到跳到位置 6 后与兔子 3 完成集结。

【评测用例规模与约定】

    对于 40% 的评测用例,2 ≤ n ≤ 500,1 ≤ pi ≤ 105,p1, p2, · · · , pn 各不相同。

    对于所有评测用例,2 ≤ n ≤ 105,1 ≤ pi ≤ 109,p1, p2, · · · , pn 各不相同。

1.分析

        位置第一个一定向第二个集结,位置最后一个一定向倒数第二个集结。

        计算除开头和结尾其他集结的结点。

        先遍历计算双向奔赴的结点的最终位置,再计算单相思结点的最终位置(和他单相思结点的位置相同)。

2.代码

#include<iostream>
#include<algorithm>
using namespace std;
const int MAX = 1e5+10;
typedef long long LL;
struct node {
    LL num;
    LL idx;
}a[MAX];
LL n,fa[MAX],re[MAX];
bool cmp1(node a, node b) {
    return a.idx < b.idx;
}
int main() {
    cin >> n;
    for (int i = 0; i < n; i++) {
        cin >> a[i].idx;
        a[i].num = i;
    }
    sort(a, a + n, cmp1);
    fa[a[0].num] = a[1].num;         //初始开头和结尾的集合点
    fa[a[n - 1].num] = a[n - 2].num;
    for (int i = 1; i < n-1; i++) {       //计算其他结点的集合点
        LL x = a[i].idx - a[i - 1].idx;
        LL y = a[i + 1].idx - a[i].idx;
        if (x <= y) {
            fa[a[i].num] = a[i - 1].num;
        }
        else {
            fa[a[i].num] = a[i + 1].num;
        }
    }
    for (int i = 0; i < n; i++) {        //计算双向奔赴的结点集合点
        if (re[a[i].num]) continue;
        int t = fa[a[i].num];
        if (fa[t] == a[i].num) {
            re[a[i].num] = (a[i].idx + a[i + 1].idx) / 2;
            re[t] = re[a[i].num];
        }
    }
    for (int i = 0; i < n; i++) {     //计算单相思结点的集合点
        if (re[a[i].num]) continue;
        int t = fa[a[i].num];
        while (re[t] == 0) {        //找到最终父结点
            t = fa[t];
        }
        re[a[i].num] = re[t];
    }
    for (int i = 0; i < n; i++) {       //输出
        if (i) cout << " " << re[i];
        else cout << re[i];
    }
    return 0;
}

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

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

相关文章

Socket 编程 UDP

目录 1. UDP网络编程 1.1 echo server 1.1.1 接口 1.1.1.1 创建套接字 1.1.1.2 绑定 1.1.1.3 bzero 1.1.1.4 htons&#xff08;主机序列转网络序列&#xff09; 1.1.1.5 inet_addr&#xff08;主机序列IP转网络序列IP&#xff09; 1.1.1.6 recvfrom&#xff08;让服务…

Jenkins实践(8):服务器A通过SSH调用服务器B执行Python自动化脚本

Jenkins实践(8):服务器A通过SSH调用服务器B执行Python自动化脚本 1、需求: 1、Jenkins服务器在74上,Python脚本在196服务器上 2、需要在服务器74的Jenkins上调用196上的脚本执行Python自动化测试 2、操作步骤 第一步:Linux Centos7配置SSH免密登录 Linux Centos7配置S…

lua的注意事项2

总之&#xff0c;下面的返回值不是10&#xff0c;a&#xff0c;b 而且

前端八股之HTML

前端秘籍-HTML篇 1. src和href的区别 src 用于替换当前元素&#xff0c;href 用于在当前文档和引用资源之间确立联系。 &#xff08;1&#xff09;src src 是 source 的缩写&#xff0c;指向外部资源的位置&#xff0c;指向的内容将会嵌入到文档中当前标签所在位置&#xff1…

鲲鹏Arm+麒麟V10,国产化信创 K8s 离线部署保姆级教程

Rainbond V6 国产化部署教程&#xff0c;针对鲲鹏 CPU 麒麟 V10 的离线环境&#xff0c;手把手教你从环境准备到应用上线&#xff0c;所有依赖包提前打包好&#xff0c;步骤写成傻瓜式操作指南。别说技术团队了&#xff0c;照着文档一步步来&#xff0c;让你领导来都能独立完成…

【C++ Qt】认识Qt、Qt 项目搭建流程(图文并茂、通俗易懂)

每日激励&#xff1a;“不设限和自我肯定的心态&#xff1a;I can do all things。 — Stephen Curry” 绪论​&#xff1a; 本章将开启Qt的学习&#xff0c;Qt是一个较为古老但仍然在GUI图形化界面设计中有着举足轻重的地位&#xff0c;因为它适合嵌入式和多种平台而被广泛使用…

IoT/HCIP实验-1/物联网开发平台实验Part2(HCIP-IoT实验手册版)

文章目录 概述产品和设备实例的产品和设备产品和设备的关联单个产品有多个设备为产品创建多个设备产品模型和物模型设备影子&#xff08;远程代理&#xff09; 新建产品模型定义编解码插件开发编解码插件工作原理消息类型与二进制码流添加消息&#xff08;数据上报消息&#xf…

Replacing iptables with eBPF in Kubernetes with Cilium

source: https://archive.fosdem.org/2020/schedule/event/replacing_iptables_with_ebpf/attachments/slides/3622/export/events/attachments/replacing_iptables_with_ebpf/slides/3622/Cilium_FOSDEM_2020.pdf 使用Cilium&#xff0c;结合eBPF、Envoy、Istio和Hubble等技术…

数学建模之最短路径问题

1 问题的提出 这个是我们的所要写的题目&#xff0c;我们要用LINGO编程进行编写这个题目&#xff0c;那么就是需要进行思考这个怎么进行构建这个问题的模型 首先起点&#xff0c;中间点&#xff0c;终点我们要对这个进行设计 2 三个点的设计 起点的设计 起点就是我们进去&am…

测试概念 和 bug

一 敏捷模型 在面对在开发项目时会遇到客户变更需求以及合并新的需求带来的高成本和时间 出现的敏捷模型 敏捷宣言 个人与交互重于过程与工具 强调有效的沟通 可用的软件重于完备的文档 强调轻文档重产出 客户协作重于合同谈判 主动及时了解当下的要求 相应变化…

zynq 级联多个ssd方案设计(ECAM BUG修改)

本文讲解采用zynq7045芯片如何实现200T容量高速存储方案设计&#xff0c;对于大容量高速存储卡&#xff0c;首先会想到采用pcie switch级联方式&#xff0c;因为单张ssd的容量是有限制的&#xff08;目前常见的m.2接口容量为4TB&#xff0c;U.2接口容量为16TB&#xff09;&…

brep2seq 论文笔记

Brep2Seq: a dataset and hierarchical deep learning network for reconstruction and generation of computer-aided design models | Journal of Computational Design and Engineering | Oxford Academic 这段文本描述了一个多头自注意力机制&#xff08;MultiHead Attenti…

【运维实战】Linux 中设置 sudo ,8个有用的 sudoers 配置!

在Linux及其他类Unix操作系统中&#xff0c;只有 root 用户能够执行所有命令并进行关键系统操作&#xff0c;例如安装更新软件包、删除程序、创建用户与用户组、修改重要系统配置文件等。 但担任 root 角色的系统管理员可通过配置sudo命令&#xff0c;允许普通系统用户执行特定…

江科大SPI串行外设接口hal库实现

hal库相关函数 初始化结构体 typedef struct {uint32_t Mode; /*SPI模式*/uint32_t Direction; /*SPI方向*/uint32_t DataSize; /*数据大小*/uint32_t CLKPolarity; /*时钟默认极性控制CPOL*/uint32_t CLKPhase; /*…

[网页五子棋][对战模块]前后端交互接口(建立连接、连接响应、落子请求/响应),客户端开发(实现棋盘/棋子绘制)

文章目录 约定前后端交互接口建立连接建立连接响应针对"落子"的请求和响应 客户端开发实现棋盘/棋子绘制部分逻辑解释 约定前后端交互接口 对战模块和匹配模块使用的是两套逻辑&#xff0c;使用不同的 websocket 的路径进行处理&#xff0c;做到更好的耦合 建立连接 …

【ArcGIS Pro微课1000例】0071:将无人机照片生成航线、轨迹点、坐标高程、方位角

文章目录 一、照片预览二、生成轨迹点三、照片信息四、查看方位角五、轨迹点连成线一、照片预览 数据位于配套实验数据包中的0071.rar,解压之后如下: 二、生成轨迹点 地理标记照片转点 (数据管理),用于根据存储在地理标记照片文件(.jpg 或 .tif)元数据中的 x、y 和 z 坐…

Ubuntu Zabbix 钉钉报警

文章目录 概要Zabbix警监控脚本技术细节配置zabbix告警 概要 提示&#xff1a;本教程用于Ubuntu &#xff0c;zabbix7.0 Zabbix警监控脚本 提示&#xff1a;需要创建一个脚本 #检查是否有 python3 和版本 rootzabbix:~# python3 --version Python 3.12.3在/usr/lib/zabbix/…

threejs顶点UV坐标、纹理贴图

1. 创建纹理贴图 通过纹理贴图加载器TextureLoader的load()方法加载一张图片可以返回一个纹理对象Texture&#xff0c;纹理对象Texture可以作为模型材质颜色贴图.map属性的值。 const geometry new THREE.PlaneGeometry(200, 100); //纹理贴图加载器TextureLoader const te…

STM32 RTC实时时钟\BKP备份寄存器\时间戳

一、Unix时间戳 想要计算当地北京时间&#xff0c;需要根据经度和闰年之类的运算得到(c语言里面可以调用time.h的函数) 二、UTC/GMT&#xff08;科普&#xff09; 三、时间戳转化 C语言的time.h模块提供了时间获取和时间戳转换的相关函数&#xff0c;可以方便的进行秒计数器、…

Axure设计案例——科技感立体柱状图

想让你的数据展示告别平淡无奇&#xff0c;成为吸引全场目光的焦点吗&#xff1f;快来瞧瞧这个Axure设计的科技感立体柱状图案例&#xff01;科技感设计风格借助逼真的立体效果打破传统柱状图的平面感&#xff0c;营造出一种令人眼前一亮的视觉震撼。每一个柱状体都仿佛是真实存…