特可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 R语言爬虫的时候元素和园代码不一样怎么解决呀
  • ¥15 VS2022多项目启动有问题
  • ¥15 SQL删除添加数据后序号不连续问题。
  • ¥15 首次运行OmniEvent运行报错
  • ¥15 有没有人知道这个问题怎么解决
  • ¥15 comsol电力电缆载流量仿真
  • ¥15 webSocket可以接TCP socket接口吗
  • ¥60 mpi并行出错,CFD++计算
  • ¥15 c#:vsto,powerpoint的外接程序中换主题颜色
  • ¥15 状态机/汽车转向灯/Sateflow