愿此后再无WA 2022-02-19 13:17 采纳率: 94.1%
浏览 92
已结题

想问问以下两种动态规划方法有什么不同?为什么会导致结果不一样?

img


第一种做法的思路是先不断递归求出下格子与右格子拿到的金币数,然后根据两者的最大值来判断是走下方还是走右方。期间使用了标记数组剪枝

def dfs(x,y):
    if x > n-1 or y > n-1:
        return 0
    if x == n-1 and y == n-1:
        return nums[x][y]
    if not used[x][y]:
        used[x][y] = max(dfs(x+1,y),dfs(x,y+1)) + nums[x][y]
    return used[x][y]
    
    
n = int(input())
nums = []
for i in range(n):
    nums.append(list(map(int,input().split())))
    
used = [[0 for i in range(n)] for j in range(n)]
print(dfs(0,0))

第二种思路是要想走到这个位置,就要看这个位置的上方拿的金币多点还是左方拿的金币多点,哪边拿得多就从哪边走过来

nums = []
n = int(input())
for i in range(n):
    nums.append(list(map(int, input().split())))
 
dp = [[0 for i in range(n)] for j in range(n)]

dp[0][0] = nums[0][0]
for i in range(1, n):
    dp[i][0] = dp[i - 1][0] + nums[i][0]
    dp[0][i] = dp[0][i - 1] + nums[0][i]

for i in range(1, n):
    for j in range(1, n):
        dp[i][j] = max(dp[i - 1][j], dp[i][j - 1]) + nums[i][j]
 
print(dp[n - 1][n - 1])

一种做法能拿满分,另一种做法只能拿30分,没有出现运行超时的情况,都是解答错误.

  • 写回答

1条回答 默认 最新

  • 爱在凌晨 2022-02-23 09:46
    关注

    看着应该没问题,递归的话,n 如果大一点话,可能会栈溢出, 不知道这种情况是不是也是解答错误

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 3月4日
  • 已采纳回答 2月24日
  • 修改了问题 2月19日
  • 创建了问题 2月19日

悬赏问题

  • ¥15 如何在scanpy上做差异基因和通路富集?
  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?
  • ¥15 c++头文件不能识别CDialog