#P1870. [NOI2010] 海拔(altitude)

[NOI2010] 海拔(altitude)

题目描述

YT 市是一个规划良好的城市,城市被东西向和南北向的主干道划分为 n×nn \times n 个区域。简单起见,可以将 YT 市看作 一个正方形,每一个区域也可看作一个正方形。从而,YT 城市中包括 (n+1)×(n+1)(n+1) \times (n+1) 个交叉路口和 2n×(n+1)2n \times (n+1) 条双向道路(简称道路),每条双向道路连接主干道上两个相邻的交叉路口。下图为一张 YT 市的地图(n=2n = 2),城市被划分为 2×22 \times 2 个区域,包括 3×33 \times 3 个交叉路口和 1212 条双向道路。

image

小 Z 作为该市的市长,他根据统计信息得到了每天上班高峰期间 YT 市每条道路两个方向的人流量,即在高峰期间沿着该方向通过这条道路的人数。每一个交叉路口都有不同的海拔高度值,YT 市市民认为爬坡是一件非常累的事情,每向上爬 hh 的高度,就需要消耗 hh 的体力。如果是下坡的话,则不需要耗费体力。因此如果一段道路的终点海拔减去起点海拔的值为 hh(注意 hh 可能是负数),那么一个人经过这段路所消耗的体力是 max{0,h}\max\{0, h\}

小 Z 还测量得到这个城市西北角的交叉路口海拔为 00,东南角的交叉路口海拔为 11(如上图所示),但其它交叉路口的海拔高度都无法得知。小 Z 想知道在最理想的情况下(即你可以任意假设其他路口的海拔高度),每天上班高峰期间所有人爬坡消耗的总体力和的最小值。

输入格式

第一行包含一个整数 nn

接下来 4n(n+1)4n(n + 1) 行,每行包含一个非负整数分别表示每一条道路每一个方向的人流量信息。

输入顺序:n(n+1)n(n + 1)个数表示所有从西到东方向的人流量,然后 n(n+1)n(n + 1) 个数表示所有从北到南方向的人流量,n(n+1)n(n + 1) 个数表示所有从东到西方向的人流量,最后是 n(n+1)n(n + 1) 个数表示所有从南到北方向的人流量。对于每一个方向,输入顺序按照起点由北向南,若南北方向相同时由西到东的顺序给出(参见样例输入)。

输出格式

仅包含一个数,表示在最理想情况下每天上班高峰期间所有人爬坡所消耗的总体力和(即总体力和的最小值),结果四舍五入到整数。

样例 #1

样例输入 #1

1
1
2
3
4
5
6
7
8

样例输出 #1

3

提示

image

数据范围

  • 对于 20%20\% 的数据:n3n \leq 3
  • 对于 50%50\% 的数据:n15n \leq 15
  • 对于 80%80\% 的数据:n40n \leq 40
  • 对于 100%100\% 的数据:1n5001 \leq n \leq 5000流量1060 \leq \text{流量} \leq 10^6 且所有流量均为整数。