P2096 最佳旅游线路

题目描述

某旅游区的街道成网格状。其中东西向的街道都是旅游街,南北向的街道都是林阴道。 由于游客众多,旅游街被规定为单行道,游客在旅游街上只能从西向东走,在林阴道上则既可从南向北走,也可以从北向南走。 阿龙想到这个旅游街游玩,他的好友阿福给了他一些建议,用分值表示所有旅游街相邻两个路口之间的街道值得游览的程度,分值是从 $-100$ 到 $100$ 的整数,所有林阴道不打分。所有分值不可能全是负分。 如图(**格子代表旅游街,竖线代表林阴道**): ![](https://cdn.luogu.com.cn/upload/pic/1235.png) 阿龙想知道,如果他从任意一个旅游街开始游览,再在任意一个旅游街结束游览,那么他经过的所有旅游街对的分值之和最大能是多少?

输入格式

输入文件的第一行是两个整数 $m$ 和 $n$,之间用一个空格隔开,$m$ 表示有 $m$ 条旅游街($1 \le m \le 100$),$n$ 表示有 $(n+1)$ 条林阴道($1 \le n \le 20001$)。接下来的 $m$ 行依次给出了由北向南每条旅游街的分值信息。每行有 $n$ 个整数,依次表示了自西向东旅游街每一小段的分值。同一行相邻两个数之间用一个空格隔开。

输出格式

输出文件只有一行,是一个整数,表示你的程序找到的最佳游览线路的总分值。

说明/提示

样例解释: 如图,阿龙从 $17$ 处开始游览,到 $34$ 处结束,答案为 $17-3+36+34=84$: ```plain -50 -47 +->[ 36]--+ -30 -23 | | | | [ 17]--+ -19 | -34 | -13 - 8 | | | | | | -42 +->[- 3]--+ -43 +->[ 34] -45 ```