#P5812. [IOI2019] 天桥

[IOI2019] 天桥

题目背景

滥用本题评测将封号

注:本题按照传统题方式进行评测,即,你的程序需要包含 main 函数

题目描述

Kenan 为沿着巴库大街某一侧的建筑和天桥绘制了一张规划图。规划图中有 nn 栋建筑,从 00n1n-1 编号。还有 mm 座天桥,从 00m1m-1 编号。这张规划图绘制在一张二维平面上,其中建筑和天桥分别是垂直和水平的线段。

ii0in10 \le i \le n-1) 栋建筑的底部坐落在坐标 (x[i],0x[i],0) 上,建筑的高度为 h[i]h[i]。因此,它对应一条连接点 (x[i],0x[i],0) 和 (x[i],h[i]x[i],h[i]) 的线段。

jj0jm10 \le j \le m-1) 座天桥的两端分别在第 l[j]l[j] 栋建筑和第 r[j]r[j] 栋建筑上,并具有正的 yy 坐标 y[j]y[j]。因此,它对应一条连接点 (x[l[j]],y[j]x[l[j]],y[j]) 和 (x[r[j]],y[j]x[r[j]],y[j]) 的线段。

称某座天桥和某栋建筑相交,如果它们有某个公共的点。因此,一座天桥在它的两个端点处与两栋建筑相交,同时还可能在中间和其他建筑相交。

Kenan 想要找出从第 ss 栋建筑的底部到第 gg 栋建筑的底部的最短路径长度,或者确认这样的路径不存在。在这里行人只能沿着建筑和天桥行走,并且不允许在地面上行走,也就是说不允许沿着 yy 坐标为 00 的水平线行走。

行人能够在任意交点从某座天桥走进某栋建筑,或者从某栋建筑走上某座天桥。如果两座天桥的端点之一在同一点上,行人也可以从其中一座天桥走上另一座天桥。

你的任务是帮助 Kenan 回答他的问题。

实现细节

你需要实现下列函数。 int64 min_distance(int[] x,int[] h,int[] l,int[] r,int[] y,int s,int g)

  • xxhh:长度为 nn 的整数数组。
  • llrryy:长度为 mm 的整数数组。
  • ssgg:两个整数。
  • 如果从第 ss 栋建筑的底部到第 gg 栋建筑的底部的最短路径存在,则该函数应该返回最短路径的长度。否则,该函数应该返回-1

输入格式

  • 11 行:nnmm
  • 2+i2+i 行(0in10 \le i \le n-1):x[i]x[i]h[i]h[i]
  • n+2+jn+2+j 行(0jm10 \le j \le m-1):l[j]l[j]r[j]r[j]y[j]y[j]
  • n+m+2n+m+2 行:ssgg

输出格式

共一行,为函数 min_distance 的返回值。

7 7
0 8
3 7
5 9
7 7
10 6
12 6
14 9
0 1 1
0 2 6
0 6 8
2 3 1
2 6 7
3 4 2
4 6 5
1 5
27

提示

样例说明

限制条件

  • 1n,m1051 \le n,m \le 10^5
  • 0x[0]<x[1]<<x[n1]1090 \le x[0] < x[1] < \cdots < x[n-1] \le 10^9
  • 1h[i]1091 \le h[i] \le 10^9(对于所有 0in10 \le i \le n-1)。
  • 0l[j]r[j]n10 \le l[j] \le r[j] \le n-1(对于所有 0jm10 \le j \le m-1)。
  • 1y[j]min(h[l[j]],h[r[j]])1 \le y[j] \le \min(h[l[j]],h[r[j]])(对于所有 0jm10 \le j \le m-1)。
  • 0s,gn10 \le s,g \le n-1
  • sgs ≠ g
  • 除在端点处外,任意两座天桥不会有其他公共的点。

子任务

  1. 1010 分)n,m50n,m \le 50
  2. 1414 分)每座天桥最多与 1010 栋建筑相交。
  3. 1515 分)s=0s=0g=n1g=n-1,且所有建筑的高度相等。
  4. 1818 分)s=0s=0g=n1g=n-1
  5. 4343 分)没有任何附加限制。