news 2026/6/10 15:25:19

打卡信奥刷题(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/10 12:22:27

Selenium 截图与元素高亮定位技巧

在 Selenium 自动化测试与网页操作中&#xff0c;元素定位失败和测试结果溯源难是两大高频痛点&#xff1a;元素因样式遮挡、动态加载、定位表达式不精准导致定位失败&#xff0c;测试用例执行异常时无法快速还原现场。而元素高亮定位能直观标记目标元素位置&#xff0c;大幅提…

作者头像 李华
网站建设 2026/6/9 19:57:07

Selenium 与 BeautifulSoup 结合解析页面

在网页数据采集的场景中&#xff0c;静态页面解析可直接用 BeautifulSoup 高效完成&#xff0c;但面对大量采用 JavaScript 动态渲染的现代网页&#xff08;如异步加载数据、动态生成 DOM 节点&#xff09;&#xff0c;单纯的 BeautifulSoup 因无法执行 JS、只能获取原始静态 H…

作者头像 李华
网站建设 2026/6/10 12:30:25

Excel金钱函数实战:用DOLLAR/RMB函数实现智能数字格式化

在处理财务数据或业务报表时&#xff0c;你是否经常需要将数字转换为规范的货币格式&#xff1f;Excel中的DOLLAR和RMB函数不仅能完成货币格式化&#xff0c;还能衍生出许多意想不到的实用技巧。 一、金钱函数基础解析 DOLLAR函数语法 DOLLAR(数字, [小数位数]) 数字&#xff…

作者头像 李华
网站建设 2026/6/9 19:53:18

8款AI工具革新软件工程毕业设计:智能化论文撰写与代码实现

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

作者头像 李华
网站建设 2026/6/9 18:40:55

毕业设计效率革命:8款AI工具优化软件工程论文与代码工作

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

作者头像 李华