#P1916. 防御迷阵

防御迷阵

题目描述

一队士兵来到了敌军城外,准备进攻敌城。敌人在城外布置一个防御迷阵,要进入城池首先必须通过城池外的防御迷阵。

迷阵由 n×mn \times m 个相同的小房间组成,每个房间与相邻四个房间之间有门可通行。而第 11 行的 mm 个房间有 mm 扇向外打开的门,是迷阵的入口。除了第 11 行和第 nn 行的房间外,每个房间都安装了激光杀伤装置,将会对进入房间的人造成一定的伤害。第 ii 行第 jj 列造成的伤害值为 aaijij。 (第 11 行和第 nn 行的 aaijij 值全部为 00)。

现在士兵打算以最小伤害代价通过迷阵,显然,他们可以选择任意多的人从任意的门进入,但必须到达第 nn 行的房间。一个士兵受到的伤害值为他在经过的路径上所有房间的伤害值中的最大值。现在,士兵们掌握了迷阵的情况,他们需要提前知道怎么安排士兵的行进路线可以使得伤害值最小。

输入

第一行有两个整数 n,mn,m 表示迷阵的大小。

接下来 nn 行,每行 mm 个数,第 ii 行第 jj 列的数表示 aija_{ij}

数据范围: 2n,m10002≤n,m≤10001a1≤aijij1000 ≤1000

输出

输出一个数,表示最小伤害代价。

样例

4 2
0 0 
3 5 
2 4 
0 0 
3