特可C 2022-09-28 13:26 采纳率: 100%
浏览 74
已结题

python 动态规划创建列表相关问题

最近在学python,在刷题的时候遇到一道动态规划题——背包问题,有一些代码看不懂。

dp = [[0]*(n+1) for _ in range(m+1)]
for i in range(1,m+1):
    for j in range(1,n+1):
        if j-w[i]>=0:
            dp[i][j] = max(dp[i-1][j], dp[i-1][j-w[i]]+v[i])
        else:
            dp[i][j] = dp[i-1][j]
return dp[m][n]

附完整问题截图:

img

想问问这些代码是什么意思?尤其是第一行,没见过这种写法,有两个地方看不懂——"[0]*(n+1)"和for后面的"_"。
还有,第四行为什么可以直接把w[j]写进来,前面的代码里也没定义过。
提前谢谢解答。

  • 写回答

7条回答 默认 最新

  • 烟雨龙升 2022-09-28 13:51
    关注

    [[0]*(n+1) for _ in range(m+1)] 这整体不是列表推导式吗
    意思就是生成一个m行n列的数组每项值为0,print(dp) 就能看出来生成的是什么了。
    for _ in range(m+1) 你应该知道for in 语句吧, 这个 _ 你不喜欢可以换成其他的不影响,反正又不使用。

    w[j] 没定义是应为没把全部代码写出来,w[] v[] 这两个不都是要输入的吗?

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(6条)

报告相同问题?

问题事件

  • 系统已结题 10月8日
  • 已采纳回答 9月30日
  • 创建了问题 9月28日

悬赏问题

  • ¥15 chaquopy python 安卓
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 有没有帮写代码做实验仿真的
  • ¥15 報錯:Person is not mapped,如何解決?
  • ¥30 vmware exsi重置后登不上
  • ¥15 易盾点选的cb参数怎么解啊
  • ¥15 MATLAB运行显示错误,如何解决?
  • ¥15 c++头文件不能识别CDialog
  • ¥15 Excel发现不可读取的内容
  • ¥15 关于#stm32#的问题:CANOpen的PDO同步传输问题