【NOIP2020普及组复赛】题3:方格取数

题3:方格取数

【题目描述】

设有 n×m 的方格图,每个方格中都有一个整数。现有一只小熊,想从图的左上角走到右下角,每一步只能向上、向下或向右走一格,并且不能重复经过已经走过的方格,也不能走出边界。小熊会取走所有经过的方格中的整数,求它能取到的整数之和的最大值。

【输入文件】

第一行有两个整数 n,m。

接下来 n 行每行 m 个整数,依次代表每个方格中的整数。

【输出文件】

一个整数,表示小熊能取到的整数之和的最大值。

【输入样例1】

3 4
1 -1 3 2
2 -1 4 -1
-2 2 -3 -1

【输出样例1】

9

【样例1说明】

在这里插入图片描述
按上述走法,取到的数之和为1+2+(-1)+4+3+2+(-1)+(-1)=9,可以证明为最大值。

在这里插入图片描述
注意,上述走法是错误的,因为第2行第2列的方格走过了两次,而根据题意,不能重复经过已经走过的方格。

在这里插入图片描述
另外,上述走法也是错误的,因为没有右下角的终点。

【输入样例2】

2 5
-1 -1 -3 -2 -7
-2 -1 -4 -1 -2

【输出样例2】

-10

【样例2说明】

在这里插入图片描述
按上述走法,取到的数之和为(-1)+(-1)+(-3)+(-2)+(-1)+(-2)=-10,可以证明为最大值。因此,请注意,取到的数之和的最大值也可能是负数。

【数据规模】

对于 20%20\%20% 的数据,n,m≤5n,m≤5n,m5

对于 40%40\%40% 的数据,n,m≤50n,m≤50n,m50

对于 70%70\%70% 的数据,n,m≤300n,m≤300

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

lpstudio

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值