特可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 腾讯云如何建立同一个项目中物模型之间的联系
  • ¥30 VMware 云桌面水印如何添加
  • ¥15 用ns3仿真出5G核心网网元
  • ¥15 matlab答疑 关于海上风电的爬坡事件检测
  • ¥88 python部署量化回测异常问题
  • ¥30 酬劳2w元求合作写文章
  • ¥15 在现有系统基础上增加功能
  • ¥15 远程桌面文档内容复制粘贴,格式会变化
  • ¥15 这种微信登录授权 谁可以做啊
  • ¥15 请问我该如何添加自己的数据去运行蚁群算法代码