news 2026/4/28 2:49:06

P3509 [POI 2010] ZAB-Frog[单调队列+倍增快速幂思想]

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
P3509 [POI 2010] ZAB-Frog[单调队列+倍增快速幂思想]

P3509 [POI 2010] ZAB-Frog

时间限制: 1.00s 内存限制: 125.00MB

复制 Markdown

中文

退出 IDE 模式

题目描述

在一个特别长且笔直的 Byteotian 小溪的河床上,有 n 块石头露出水面。它们距离小溪源头的距离分别为 p1​<p2​<⋯<pn​。一只小青蛙正坐在其中一块石头上,准备开始它的跳跃训练。每次青蛙跳跃到距离它所在石头第 k 近的石头上。具体来说,如果青蛙坐在位置 pi​ 的石头上,那么它将跳到这样的 pj​ 上,使得:

∣{pa​:∣pa​−pi​∣<∣pj​−pi​∣}∣≤k and ∣{pa​:∣pa​−pi​∣≤∣pj​−pi​∣}∣>k

如果 pj​ 不是唯一的,那么青蛙在其中选择距离源头最近的石头。对于每一块石头分别计算,若青蛙从这块石头开始跳跃,经过 m 次跳跃后最终会停留在哪一块石头上?

输入格式

标准输入的第一行包含三个整数 n、k 和 m(1≤k<n≤1000000,1≤m≤1018),用空格分隔,分别表示石头的数量、参数 k 和计划跳跃的次数。第二行包含 n 个整数 pj​(1≤p1​<p2​<⋯<pn​≤1018),用空格分隔,表示小溪河床上连续石头的位置。

输出格式

你的程序应在标准输出上打印一行,包含 n 个整数 r1​,r2​,⋯,rn​,用空格分隔。数字 ri​ 表示从输入顺序中的第 i 块石头开始跳跃 m 次后,青蛙最终停留的石头编号。

显示翻译

题意翻译

输入输出样例

输入 #1复制运行

5 2 4 1 2 4 7 10

输出 #1复制运行

1 1 3 1 1

说明/提示

样例 #1 解释:

图中展示了青蛙从每块石头跳跃(单次跳跃)到的位置。

题面翻译由 ChatGPT-4o 提供

首先单调队列维护第k大的 首先维护一个长度为k的窗口 我们只需要比较左端右端 如果右端+1 的位置小于左端 那么窗口右滑 直到划不动 然后比较左右的大小 确定跳跃一步的位置

然后根据m开始倍增跳越 类似于快速幂的做法 如果是奇数 那么先跳一次 偶数的话那就令步长连续跳跃两次 也就是步长翻倍 可以类比快速幂理解;

#include <bits/stdc++.h> using namespace std; const int N=1e6+5; #define int long long int net[N],net2[N],ans[N],a[N]; long long n,k,m; signed main() { ios::sync_with_stdio(0); cin.tie(0); cout.tie(0); cin>>n>>k>>m; for(int i=1;i<=n;i++)cin>>a[i],ans[i]=i; int l=1,r=k+1; for(int i=1;i<=n;i++){ while(r+1<=n&&a[r+1]-a[i]<a[i]-a[l])l++,r++; int disr=a[r]-a[i],disl=a[i]-a[l]; if(disl>=disr)net[i]=l; else net[i]=r; } while(m){ if(m&1) for(int i=1;i<=n;i++)ans[i]=net[ans[i]]; for(int i=1;i<=n;i++)net2[i]=net[i]; for(int i=1;i<=n;i++)net[i]=net2[net2[i]]; m>>=1; } for(int i=1;i<=n;i++) cout<<ans[i]<<' '; return 0; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/26 2:50:40

基于微信小程序的牙科诊所预约服务平台的设计和实现

前言 &#x1f31e;博主介绍&#xff1a;✌CSDN特邀作者、全栈领域优质创作者、10年IT从业经验、码云/掘金/知乎/B站/华为云/阿里云等平台优质作者、专注于Java、小程序/APP、python、大数据等技术领域和毕业项目实战&#xff0c;以及程序定制化开发、文档编写、答疑辅导等。✌…

作者头像 李华
网站建设 2026/4/27 18:38:36

不用写代码,用工作流搭建智能Web应用

不用写代码&#xff0c;用工作流搭建智能Web应用 【免费下载链接】Awesome-Dify-Workflow 分享一些好用的 Dify DSL 工作流程&#xff0c;自用、学习两相宜。 Sharing some Dify workflows. 项目地址: https://gitcode.com/GitHub_Trending/aw/Awesome-Dify-Workflow 你…

作者头像 李华
网站建设 2026/4/26 2:48:37

手把手教你部署Open-AutoGLM,让AI替你操作手机

手把手教你部署Open-AutoGLM&#xff0c;让AI替你操作手机 1. 引言&#xff1a;什么是 Open-AutoGLM&#xff1f; AutoGLM-Phone 是由智谱 AI 开源的手机端 AI Agent 框架&#xff0c;基于视觉语言模型&#xff08;VLM&#xff09;构建&#xff0c;能够以多模态方式理解安卓设…

作者头像 李华
网站建设 2026/4/26 0:48:50

高效歌词提取工具:5分钟学会跨平台歌词批量下载技巧

高效歌词提取工具&#xff1a;5分钟学会跨平台歌词批量下载技巧 【免费下载链接】163MusicLyrics Windows 云音乐歌词获取【网易云、QQ音乐】 项目地址: https://gitcode.com/GitHub_Trending/16/163MusicLyrics 还在为找不到心爱歌曲的歌词而烦恼吗&#xff1f;想要把网…

作者头像 李华
网站建设 2026/4/26 2:50:01

云音乐歌词获取工具完整指南:轻松下载网易云和QQ音乐歌词

云音乐歌词获取工具完整指南&#xff1a;轻松下载网易云和QQ音乐歌词 【免费下载链接】163MusicLyrics Windows 云音乐歌词获取【网易云、QQ音乐】 项目地址: https://gitcode.com/GitHub_Trending/16/163MusicLyrics 还在为本地音乐缺少歌词而烦恼吗&#xff1f;这款强…

作者头像 李华
网站建设 2026/4/27 18:41:02

Qwen1.5-0.5B-Chat教育辅导实战:个性化答疑系统搭建教程

Qwen1.5-0.5B-Chat教育辅导实战&#xff1a;个性化答疑系统搭建教程 1. 引言 1.1 学习目标 本文旨在指导开发者从零开始&#xff0c;基于 ModelScope 生态构建一个轻量级、可本地部署的个性化教育答疑系统。通过集成阿里通义千问系列中的 Qwen1.5-0.5B-Chat 模型&#xff0c…

作者头像 李华