news 2026/6/8 19:56:50

打卡信奥刷题(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/6/2 14:41:16

微软MOS认证2月份考试时间

1月马上接近尾声&#xff0c;微软MOS认证2月份都有哪些考试排期呢&#xff0c;快来看看吧~

作者头像 李华
网站建设 2026/5/10 10:23:01

8款AI应用改变软件工程毕设:智能论文撰写与程序复现

文章总结表格&#xff08;工具排名对比&#xff09; 工具名称 核心优势 aibiye 精准降AIGC率检测&#xff0c;适配知网/维普等平台 aicheck 专注文本AI痕迹识别&#xff0c;优化人类表达风格 askpaper 快速降AI痕迹&#xff0c;保留学术规范 秒篇 高效处理混AIGC内容&…

作者头像 李华
网站建设 2026/5/24 12:35:49

CKEDITOR粘贴WORD图片失败时如何通过示例排查?

企业级文档导入与粘贴解决方案 项目背景与需求综述 作为西安高新技术企业和软件企业项目负责人&#xff0c;我们近期在企业网站后台管理系统的升级中遇到了一系列文档处理的需求。这些需求源于我们服务的党政、国防军工、金融、高校、医疗、汽车制造等多个关键行业的客户&…

作者头像 李华
网站建设 2026/6/5 7:44:01

Ollama REST API - OpenAI Compatibility

本节内容我们来看一下 OpenAI Compatibility。 OpenAI 的 API 接口是大模型应用开发中最常用、且集成度最高的 API 接口规范&#xff0c;其兼容接口主要包括&#xff1a; chat/completionscompletionsmodelsembeddings 我们上两节课程内容中介绍的/api/generate 和 /api/chat…

作者头像 李华