news 2026/3/29 23:05:51

打卡信奥刷题(2749)用C++实现信奥题 P3645 [APIO2015] 雅加达的摩天楼

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
打卡信奥刷题(2749)用C++实现信奥题 P3645 [APIO2015] 雅加达的摩天楼

P3645 [APIO2015] 雅加达的摩天楼

题目描述

印尼首都雅加达市有NNN座摩天楼,它们排列成一条直线,我们从左到右依次将它们编号为000N−1N − 1N1。除了这NNN座摩天楼外,雅加达市没有其他摩天楼。

MMM只叫做 “doge” 的神秘生物在雅加达市居住,它们的编号依次是000M−1M − 1M1。编号为iii的 doge 最初居住于编号为BiB_iBi的摩天楼。每只 doge 都有一种神秘的力量,使它们能够在摩天楼之间跳跃,编号为iii的 doge 的跳跃能力为PiP_iPiPi>0P_i > 0Pi>0)。

在一次跳跃中,位于摩天楼bbb而跳跃能力为ppp的 doge 可以跳跃到编号为b−pb - pbp(如果0≤b−p<N0 \leq b - p < N0bp<N)或b+pb + pb+p(如果0≤b+p<N0 \leq b + p < N0b+p<N)的摩天楼。

编号为000的 doge 是所有 doge 的首领,它有一条紧急的消息要尽快传送给编号为111的 doge。任何一个收到消息的 doge 有以下两个选择:

  • 跳跃到其他摩天楼上;
  • 将消息传递给它当前所在的摩天楼上的其他 doge。

请帮助 doge 们计算将消息从000号 doge 传递到111号 doge 所需要的最少总跳跃步数,或者告诉它们消息永远不可能传递到111号 doge。

输入格式

输入的第一行包含两个整数NNNMMM

接下来MMM行,每行包含两个整数BiB_iBiPiP_iPi

输出格式

输出一行,表示所需要的最少步数。如果消息永远无法传递到111号 doge,输出−1−11

输入输出样例 #1

输入 #1

5 3 0 2 1 1 4 1

输出 #1

5

说明/提示

【样例解释】

下面是一种步数为555的解决方案:

000号 doge 跳跃到222号摩天楼,再跳跃到444号摩天楼(222步)。

000号 doge 将消息传递给222号 doge。

222号 doge 跳跃到333号摩天楼,接着跳跃到222号摩天楼,再跳跃到111号摩天楼(333步)。

222号 doge 将消息传递给111号 doge。

【数据范围】

所有数据都保证0≤Bi<N0 \leq B_i < N0Bi<N

子任务 1 (10 分)1≤N≤101 \leq N \leq 101N10

1≤Pi≤101 \leq P_i \leq 101Pi10

2≤M≤32 \leq M \leq 32M3

子任务 2 (12 分)1≤N≤1001 \leq N \leq 1001N100

1≤Pi≤1001 \leq P_i \leq 1001Pi100

2≤M≤20002 \leq M \leq 20002M2000

子任务 3 (14 分)1≤N≤20001 \leq N \leq 20001N2000

1≤Pi≤20001 \leq P i ≤ 20001Pi2000

2≤M≤20002 \leq M \leq 20002M2000

子任务 4 (21 分)1≤N≤20001 \leq N \leq 20001N2000

1≤Pi≤20001 \leq P_i \leq 20001Pi2000

2≤M≤300002 \leq M \leq 300002M30000

子任务 5 (43 分)1≤N≤300001 \leq N \leq 300001N30000

1≤Pi≤300001 \leq P_i \leq 300001Pi30000

2≤M≤300002 \leq M \leq 300002M30000

C++实现

#include<bits/stdc++.h>usingnamespacestd;constintN=30000+5;bitset<N>vis[N];vector<int>p[N];structnode{intpos,jump,dep;node(){}node(int_p,int_j,int_d){pos=_p;jump=_j;dep=_d;}};deque<node>q;intn,B[N],P[N];voidbfs(){node u;while(!q.empty()){u=q.front();q.pop_front();//cout<<u.pos<<" "<<u.jump<<endl;if(u.pos==B[1])cout<<u.dep,exit(0);if(vis[u.pos][u.jump])continue;vis[u.pos][u.jump]=1;for(inti=0;i<p[u.pos].size();++i)q.push_front(node(u.pos,p[u.pos][i],u.dep));if(u.pos-u.jump>=0)q.push_back(node(u.pos-u.jump,u.jump,u.dep+1));if(u.pos+u.jump<n)q.push_back(node(u.pos+u.jump,u.jump,u.dep+1));}cout<<-1;}intmain(){intm;cin>>n>>m;for(inti=0;i<m;++i){cin>>B[i]>>P[i];p[B[i]].push_back(P[i]);}q.push_back(node(B[0],P[0],0));bfs();return0;}

后续

接下来我会不断用C++来实现信奥比赛中的算法题、GESP考级编程题实现、白名单赛事考题实现,记录日常的编程生活、比赛心得,感兴趣的请关注,我后续将继续分享相关内容

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/27 12:25:27

企业级工厂车间管理系统管理系统源码|SpringBoot+Vue+MyBatis架构+MySQL数据库【完整版】

摘要 现代制造业的快速发展对工厂车间的管理提出了更高的要求&#xff0c;传统的管理方式已无法满足高效、精准、实时监控的需求。随着工业4.0和智能制造的推进&#xff0c;企业亟需一套集成化、数字化的车间管理系统&#xff0c;以实现生产流程的自动化、数据的可视化以及资源…

作者头像 李华
网站建设 2026/3/29 1:34:23

蜜语聊带后台源码 好玩的秘密语言工具 多种类型可选

内容目录一、详细介绍二、效果展示1.部分代码2.效果图展示三、学习资料下载一、详细介绍 好玩的秘密语言工具&#xff0c;带后台支持在线加解密&#xff0c;有多种类型可选 二、效果展示 1.部分代码 代码如下&#xff08;示例&#xff09;&#xff1a; 2.效果图展示 三、学…

作者头像 李华
网站建设 2026/3/26 17:52:27

[特殊字符]_微服务架构下的性能调优实战[20260126045356]

作为一名经历过多个微服务架构项目的工程师&#xff0c;我深知在分布式环境下进行性能调优的复杂性。微服务架构虽然提供了良好的可扩展性和灵活性&#xff0c;但也带来了新的性能挑战。今天我要分享的是在微服务架构下进行性能调优的实战经验。 &#x1f4a1; 微服务架构的性…

作者头像 李华
网站建设 2026/3/27 16:11:19

互联网产品CKEDITOR粘贴截图生成URL的示例?

CMS企业官网Word导入功能开发手记 需求分析与技术调研 作为北京的一名.NET开发工程师&#xff0c;最近接手的企业CMS官网项目新增了文档导入需求。客户希望在新闻发布模块中实现Word/Excel/PPT/PDF文档导入和一键粘贴功能&#xff0c;同时保留完整样式和多媒体内容。 需求拆…

作者头像 李华
网站建设 2026/3/27 4:33:46

实用蛋白质谱分析数据库资源

实用蛋白质谱分析数据库资源 1. GPMdb GPMdb全称为Global Proteome Machine Database。这是一个持续更新的大型数据库&#xff0c;包含许多被质谱鉴定过的蛋白质质谱数据。 网站链接&#xff1a;http://gpmdb.thegpm.org 用蛋白质谱分析数据库资源 网站界面很简单&#xff0…

作者头像 李华
网站建设 2026/3/27 16:02:36

弗劳恩霍夫,填补有机半导体表征领域的空白

弗劳恩霍夫 IPMS 测量适配器&#xff1a;为精准材料分析树立全新标杆弗劳恩霍夫光子微系统研究所&#xff08;IPMS&#xff09;成功研发出一款创新芯片&#xff0c;宣称此芯片将彻底变革有机材料的表征模式&#xff0c;并加速新型电子应用的研发进程。新开发的一款测量适配器&a…

作者头像 李华