#P15828. [JOI Open 2014] Pinball

[JOI Open 2014] Pinball

说明

Alice 喜欢一款名为弹球(Pinball)的视频游戏。弹球的规则如下。

弹球的棋盘是一个有 (M+2)(M + 2) 行和 NN 列的网格。棋盘的第一行是棋盘的顶部,第 (M+2)(M + 2) 行是棋盘的底部。位于第 ii 行、第 jj 列的格子记为 (i,j)(i, j)

一个球会出现在棋盘第一行的某个格子上,并垂直向下落向棋盘底部。也就是说,如果一个球出现在格子 (1,i)(1, i)1iN1 \leq i \leq N),它将会依次经过 (j,i)(j, i)2jM+12 \leq j \leq M + 1),并最终到达底部的格子 (M+2,i)(M + 2, i)。当 Alice 成功击回球时,她会获得分数。

一天,Alice 注意到,由于球可能到达底部的任何格子,这使得击球变得困难。Alice 决定在棋盘上适当地放置一些如下所述的装置,使得球可能到达的底部格子有且仅有一个

共有 MM 个装置,编号从 1 到 MM。每个装置都与棋盘的行平行。装置 ii1iM1 \leq i \leq M)位于从 (i+1,Ai)(i + 1, A_i)(i+1,Bi)(i + 1, B_i) 的格子上,因此它总共覆盖 (BiAi+1)(B_i - A_i + 1) 个格子。当一个球到达该装置上的任意格子时,它会被传送到格子 (i+1,Ci)(i + 1, C_i)AiCiBiA_i \leq C_i \leq B_i)。之后,被传送的球将沿着第 CiC_i 列垂直移动。每个装置对同一个球最多作用一次。

在游戏中,放置装置 ii1iM1 \leq i \leq M)需要支付 DiD_i 日元。她将从这 MM 个装置中选择一部分放置在棋盘上,使得球可能到达的底部格子有且仅有一个。她希望通过高效地放置装置来最小化总成本。

:::align{center}

图示:一个弹球棋盘的例子。这里 M=2M = 2N=4N = 4。一个球出现在第一行的格子 (1,2)(1, 2)。然后,球将移动到 (2,2)(2, 2),并被装置 1 传送到 (2,3)(2, 3)。最终它到达底部的格子 (4,3)(4, 3)。 :::

任务

编写一个程序,根据给定的棋盘大小和装置信息,计算出使得球可能到达的底部格子有且仅有一个所需的最小总成本。

输入格式

从标准输入读取以下数据。

  • 输入的第一行包含两个以空格分隔的整数 M,NM, N。这表示棋盘有 (M+2)(M + 2) 行和 NN 列,且装置的数量为 MM
  • 接下来的 MM 行中,第 ii 行(1iM1 \leq i \leq M)包含四个以空格分隔的整数 Ai,Bi,Ci,DiA_i, B_i, C_i, D_i。这表示装置 ii 位于从 (i+1,Ai)(i + 1, A_i)(i+1,Bi)(i + 1, B_i) 的格子上。装置 ii 总共覆盖 (BiAi+1)(B_i - A_i + 1) 个格子。装置 ii 会将到达这些格子中任意一个的球传送到格子 (i+1,Ci)(i + 1, C_i)。放置装置 ii 的成本为 DiD_i 日元。

输出格式

向标准输出写入一行。输出应包含一个整数,表示使得球可能到达的底部格子有且仅有一个所需放置装置的最小总成本。如果无法通过放置装置满足该条件,则输出 1-1

5 6
2 4 3 5
1 2 2 8
3 6 5 2
4 6 4 7
2 4 3 10
25
3 5
2 4 3 10
1 3 1 20
2 5 4 30
-1

提示

样例 1 解释

棋盘和装置的位置如下图所示。每个装置上方标注的数字表示放置它所需的成本。

:::align{center} :::

如果从五个装置中选择装置 2、4、5 进行放置,棋盘将变为如下图所示。

:::align{center} :::

此时,从第一行任意格子出现的球最终都会到达底部的格子 (7,3)(7, 3)。放置这些装置的总成本为 25 日元。由于无法用低于 25 日元的总成本实现“球可能到达的底部格子有且仅有一个”这一条件,因此你应该输出 25。

样例 2 解释

无法通过放置装置使得球可能到达的底部格子有且仅有一个。

约束条件

所有输入数据满足以下条件。

  • 1M1000001 \leq M \leq 100\,000
  • 2N10000000002 \leq N \leq 1\,000\,000\,000
  • 1AiCiBiN1 \leq A_i \leq C_i \leq B_i \leq N1iM1 \leq i \leq M)。
  • 1Di10000000001 \leq D_i \leq 1\,000\,000\,0001iM1 \leq i \leq M)。

子任务

子任务 1 [11 分]

满足以下条件:

  • M10M \leq 10
  • N1000N \leq 1000

子任务 2 [18 分]

满足以下条件:

  • M200M \leq 200

子任务 3 [22 分]

满足以下条件:

  • M1000M \leq 1000

子任务 4 [49 分]

  • 无额外约束。

翻译由 DeepSeek V3.2 完成