香菇蓝瘦,我要开始怀疑人生了!!

同样是动态规划!!为什么我的程序通过不了全部测试???😭太匪夷所思了
R,C = list(map(int, input().split()))

mat = []
dp = [[0]*C for _ in range(R)]
for x in range(R):
    mat.append(list(map(int, input().split())))
if R==1 and C==1:
    print(mat[0][0])
    exit()
for j in range(C):
    for i in range(R):
        if i == 0 and j == 0:
            dp[i][j] = mat[i][j]
        elif i == 0 and j != 0:
            dp[i][j] = max(dp[i][j-1],dp[i+1][j-1]) + mat[i][j]
        elif i != 0 and j == 0:
            dp[i][j] = 0
        elif i == R-1 and j != 0:
            dp[i][j] = max(dp[i-1][j-1],dp[i][j-1]) + mat[i][j]
        else:
            dp[i][j] = max(dp[i-1][j-1],dp[i][j-1],dp[i+1][j-1]) + mat[i][j]
print(dp[R-1][C-1])


全部评论
从左下角转移过来的点不一定能够到达
1 回复 分享
发布于 2020-07-01 13:20

相关推荐

点赞 评论 收藏
分享
04-03 18:59
吉林大学 Java
大专人陈义:别投了,我看到有人点了第二个链接投递,还没退出界面,不合适的邮件就发过来了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务