【倍增】【线段树】雨林跳跃(luogu 7599[APIO 2021 T2])

正题

luogu 7599[APIO 2021 T2]


题目大意

给你一排树中每棵树的高度,每次跳跃可以跳到左/右边第一棵比该树高的树,问你从A-B中某棵树跳到C-D中的某棵树的最小步数(A⩽B<C⩽DA\leqslant B< C\leqslant DAB<CD


解题思路

在这里插入图片描述

上图为例,绿色为起点,蓝色为终点

对于起点,不难发现,要选择低于最高终点的点中尽量高度,且右边的起点都比它低

低于最高终点保证了可以跳到终点,而最高的保证了跳的步数尽可能少,如果右边有比它高的,通过前面的性质,可以发现无法跳到终点(用倍增实现)

起点确定之后考虑往左右跳,由于A⩽B<C⩽DA\leqslant B< C\leqslant DAB<CD,往终点走一定是往右跳

那么往左有什么意义呢,对于4,2,3,4,5,当位于2时,往右跳到5要3步,而先往左跳一步只要两步,由此,往左跳的高度如果大于右边若干树的高度,那么往左跳可以使答案跟优

那么把跳跃分成往上和往右两步,设fji,jfj_{i,j}fji,j为位于i向上跳2j2^j2j步的最高高度,因为跳到右边可以使往右跳少一步,所以往上跳一定能使往右跳步数减少,且跳得越高,少得越多

所以往上跳跳到第一个点,使得该点高于起点终点之间的所有点,然后往右跳即可


代码

#include<cmath>
#include<vector>
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
#define ll long long
#define NN 200021
using namespace std;
int n, m, v, x, A, B, C, D, lg, bg, hed, top, ans;
int h[NN], d[NN], lj[NN][20], rj[NN][20], hj[NN][20];
struct node
{int v, s;bool operator <(const node &b) const{return s > b.s;}
}b[NN];
struct Tree//线段树找最大
{int a[NN<<2];#define ls x*2#define rs x*2+1void build(int x, int l, int r){if (l == r){a[x] = h[l];return;}int mid = l + r >> 1;build(ls, l, mid);build(rs, mid + 1, r);a[x] = max(a[ls], a[rs]);return;}int ask(int x, int L, int R, int l, int r){if (L == l && R == r) return a[x];int mid = L + R >> 1;if (r <= mid) return ask(ls, L, mid, l, r);else if (l > mid) return ask(rs, mid + 1, R, l, r);else return max(ask(ls, L, mid, l, mid), ask(rs, mid + 1, R, mid + 1, r));}
}T;void init(int N, std::vector<int> H)
{n = N;int lg = log2(n);for (int i = 1; i <= n; ++i){h[i] = H[i - 1];b[i].v = i;b[i].s = h[i];lj[i][0] = i;for (int j = 1; j <= log2(i); ++j)//向左跳,找起点,存的是最高高度if (h[lj[i][j - 1]] > h[lj[i - (1<<(j - 1))][j - 1]]) lj[i][j] = lj[i][j - 1];else lj[i][j] = lj[i - (1<<(j - 1))][j - 1];}for (int i = 1; i <= n; ++i)//向高跳{while(h[d[top]] < h[i] && top) top--;hj[i][0] = d[top];d[++top] = i;}top = 0;for (int i = n; i > 0; --i){while(h[d[top]] < h[i] && top) top--;if (h[hj[i][0]] < h[d[top]]) hj[i][0] = d[top];rj[i][0] = d[top];for (int j = 1; j <= lg; ++j)//向右跳rj[i][j] = rj[rj[i][j - 1]][j - 1];d[++top] = i;}sort(b + 1, b + 1 + n);for (int i = 1; i <= n; ++i)for (int j = 1; j <= lg; ++j)hj[b[i].v][j] = hj[hj[b[i].v][j - 1]][j - 1];//倍增T.build(1, 1, n);
}int minimum_jumps(int A, int B, int C, int D)
{A++;B++;C++;D++;lg = log2(n);hed  = T.ask(1, 1, n, C, D);if (B + 1 <= C - 1) v = T.ask(1, 1, n, B + 1, C - 1);else{if (h[B] < hed) return 1;return -1;}if (v > hed) return -1;x = B;bg = B;for (int i = lg; i >= 0; --i)if (h[lj[x][i]] <= hed && x - (1<<i) + 1 >= A){if (h[bg] < h[lj[x][i]]) bg = lj[x][i];//找起点x -= (1<<i);}ans = 0;for (int i = lg; i >= 0; --i)if (hj[bg][i] && h[hj[bg][i]] < v){bg = hj[bg][i];//向高跳ans += (1<<i);}if (hj[bg][0] && h[hj[bg][0]] < hed && h[bg] < v){bg = hj[bg][0];ans++;}for (int i = lg; i >= 0; --i)if (rj[bg][i] && rj[bg][i] < C)//向右跳{bg = rj[bg][i];ans += (1<<i);}if (h[bg] <= hed) return ans + 1;else return -1;
}

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

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

相关文章

dotnetClub 的前世今生

三年之前&#xff0c;我做过一个在线调查&#xff0c;当时有不少人还是对一个在线社区表示出期待。.NET Core 技术正风声水起&#xff0c;所以我就开始了用它来开发一个论坛的计划。最近正式将项目推动到了一个 MVP 的状态。感兴趣的朋友&#xff0c;现在可以访问 preview.dotn…

【每日一题】7月13日题目精讲—Kingdom

【每日一题】7月13日题目精讲—Kingdom 文章目录题目描述题解&#xff1a;代码:时间限制&#xff1a;C/C 2秒&#xff0c;其他语言4秒 空间限制&#xff1a;C/C 1048576K&#xff0c;其他语言2097152K 64bit IO Format: %lld题目描述 X王国有n位官员&#xff0c;编号从1到n。国…

CanalSharp-mysql数据库binlog的增量订阅消费组件Canal的.NET客户端

一.前言CanalSharp是阿里巴巴开源项目mysql数据库binlog的增量订阅&消费组件 Canal 的.NET客户端&#xff0c;关于什么是 Canal&#xff1f;又能做什么&#xff1f;我会在后文为大家一一介绍。CanalSharp 这个项目&#xff0c;是由我和 WithLin(主要贡献) 完成&#xff0c;…

【每日一题】7月14日题目精讲—压缩

来源&#xff1a;牛客网&#xff1a; 时间限制&#xff1a;C/C 1秒&#xff0c;其他语言2秒 空间限制&#xff1a;C/C 262144K&#xff0c;其他语言524288K 64bit IO Format: %lld题目描述 给一个由小写字母组成的字符串&#xff0c;我们可以用一种简单的方法来压缩其中的重复…

【DevOps+LIVE】直播复盘 – DevOps能力成长模型2018首发

昨天晚上小编和DevOpsDays中国核心组织者刘征老师和张乐老师一起嗨了一把&#xff0c;本来规划进行1小时的直播结果延长到了2个小时才结束&#xff0c;观众人数在前半段一直处于增长状态&#xff0c;直到开播一小时到达顶峰。小伙伴也非常给力&#xff0c;一共提出了40多个问题…

Emit动态代理.NetCore迁移之旅

前言】前面我们介绍了Aop 从静态代理到动态代理&#xff1a;https://www.cnblogs.com/7tiny/p/9657451.html我们在.NetFramework平台下使用微软提供的Emit技术实现了动态代理类的生成。但是.NetCore作为微软.Net平台的春天&#xff0c;如果类库光支持.NetFramework&#xff0c;…

asp.net core结合Gitlab-CI实现自动化部署

一、前言在之前的文章中写过k8sJenkinsGitLab-自动化部署asp.net core项目 的topic&#xff0c;这次讲解一下gitlab-ci的CI/CD&#xff0c;说实话&#xff0c;自动化部署是在是非常的舒服&#xff0c;而且gitlab-ci很适合中小项目的部署&#xff0c;大项目推荐使用k8s。阅读目录…

[译]ABP vNext介绍

译者注ASP.NET Boilerplate是.Net平台非常优秀的一个开源Web应用程序框架,在国内也有大量的粉丝.近日, 本人在github上闲逛, 发现ASP.NET Boilerplate团队又悄悄的建立了一个新项目: ABP vNext从名称可以看出来, 这是ASP.NET Boilerplate的下一代框架. 那么, 为什么要开发这个新…

【KMP】重复子串(ybtoj KMP-2)

正题 ybtoj KMP-2 题目大意 问你一个字符串最多由多少个相同的字符串组合而成 解题思路 如下图&#xff0c;先用KMP求出nx数组&#xff0c;那么有1∼nxn1\sim nx_n1∼nxn​和(n−nxn)∼n(n-nx_n)\sim n(n−nxn​)∼n相匹配 不难推出1∼(n−nxn)1\sim (n-nx_n)1∼(n−nxn​)…

C# 8小特性

对于C# 8&#xff0c;有吸引了大多数注意力的重大特性&#xff0c;如默认接口方法和可空引用&#xff0c;也有许多小特性被考虑在内。本文将介绍几例可能加入C#未来版本的小特性。新的赋值运算符&#xff1a;&&和||从第一个版本开始&#xff0c;C#就支持把等号和另外一…

【KMP】周期长度和(luogu 3435/ybtoj KMP-3)

正题 luogu 3435 ybtoj KMP-3 题目大意 定义S的proper前缀为S中非空且len<|S|的前缀&#xff0c;若Q是A的proper前缀&#xff0c;且A是QQ的前缀 现在问你字符串S所有前缀的最大周期之和 解题思路 如上图&#xff0c;对于一个字符串S&#xff0c;如果有周期Q&#xff0c;那…

dotnet core 开发无缝兼容Http和Websocket协议的接口服务

在应用接口开发中往往要针对不同协义开发相应的代理服务&#xff0c;但对于Websocket和http这两种协议来说就有些不同&#xff0c;从实现上来看Websocket可以说是Http的升级子协议&#xff0c; 两者在协议处理上基本一致&#xff0c;具体可以在解释Body上有所不同。FastHttpApi…

centos7 lldb 调试netcore应用的内存泄漏和死循环示例(dump文件调试)

写个demo来玩一玩linux平台下使用lldb加载sos来调试netcore应用。当然&#xff0c;在真实的产线环境中需要分析的数据和难度远远高于demo所示&#xff0c;所以demo的作用也仅仅只能起到介绍工具的作用。通常正常情况下&#xff0c;分析个几天才能得出一个结论的的结果都还是比较…

.NET微服务方案调查

.NET Core就是专门针对模块化的微服务架构而设计&#xff0c;调查下大家选择.NET微服务情况&#xff0c;如果你有微服务方面的需求可以找我哦&#xff0c;可加我微信geffzhang&#xff1a;相关文章&#xff1a;Service Fabric 与Ocelot 的集成Ocelot简易教程&#xff08;二&…

中国开源年会 COSCon 2018 今起接受报名!

大会官网二维码名片&#xff1a;点击文末左下角阅读原文&#xff0c;直达报名链接写在大会前开源 20 年&#xff0c;我们遇到了什么问题&#xff1f;‍围绕开源的方式来开发软件项目&#xff0c;正在走向业界的主流。随着开源的崛起&#xff0c;相应的问题也来了&#xff1a;Re…

.Net Core应用框架Util介绍(四)

上篇介绍了Util Angular Demo的目录结构和运行机制&#xff0c;本文介绍Util封装Angular的基本手法及背后的动机。Angular应用由Ts和Html两部分构成&#xff0c;本文介绍第一部分。Angular Ts的封装Ts是Angular的代码部分&#xff0c;用于编写页面逻辑。依赖注入( Dependency I…

2020牛客暑期多校训练营(第四场)

2020牛客暑期多校训练营&#xff08;第四场&#xff09; 这场属实有点难受 文章目录A Ancient DistanceB Basic Gcd Problem题目代码&#xff1a;C Count New StringD Dividing StringsE EliminateF Finding the Order题意&#xff1a;题解&#xff1a;代码&#xff1a;G Geome…

《C# 程序员的自我修养》送书活动结果公布

截止到9月28日24&#xff1a;00 &#xff0c;本次送书活动《C# 程序员的自我修养》共收到150多位同学参与回复。以下5位同学将获赠书籍一本&#xff1a;夏树、Damon、水墨清华、天天、kang以上同学请加小二微信领取赠书小二微信&#xff1a;geffzhang.NET社区新闻&#xff0c;深…

使用 dotTrace 分析 .NET Core 代码问题

0.背景在项目开发之中&#xff0c;前期可能主要以保证任务完成为主&#xff0c;对于性能优化主要在于开发完成之后再来进行。可能在测试的时候发现部分接口的代码执行时间过长&#xff0c;但是又毫无头绪&#xff0c;这个时候你就需要性能分析工具来协助你排查问题了。常规性能…

【每日一题】7月17日题目精讲—BOWL 碗的叠放

【每日一题】7月17日题目精讲—BOWL 碗的叠放 时间限制&#xff1a;C/C 1秒&#xff0c;其他语言2秒 空间限制&#xff1a;C/C 262144K&#xff0c;其他语言524288K 64bit IO Format: %lld题目描述 小H有n个碗需要放进橱柜&#xff0c;她希望将他们叠起来放置。你知道每个碗都…