码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 01背包问题


    目录

    题目

    解题思路​

    初始化二维矩阵的细节

    python生成矩阵为何[[0 for i in range(n)] for j in range(m)]而不能[[0]*n]*m

     [[0]*2]*2的存储形式

    [[0 for i in range(3)] for j in range(3)]的存储形式

    [0 for i in range(3) for j in range(3)]的存储形式

    题解


    题目

    有 N 件物品和一个容量是 V 的背包。每件物品只能使用一次。

    第 ii 件物品的体积是 vi,价值是 wi。

    求解将哪些物品装入背包,可使这些物品的总体积不超过背包容量,且总价值最大。
    输出最大价值。

    输入格式

    第一行两个整数,N,V,用空格隔开,分别表示物品数量和背包容积。

    接下来有 N 行,每行两个整数 vi,wi,用空格隔开,分别表示第 i 件物品的体积和价值。

    输出格式

    输出一个整数,表示最大价值。

    数据范围

    0 0

    输入样例

    1. 4 5
    2. 1 2
    3. 2 4
    4. 3 4
    5. 4 5

    输出样例:

    8

    解题思路

            首先,我们先声明一个大小为f[n][c]的二维数组,f[i][j]表示在面对第i件物品,且背包容量为j时所能获得的最大价值。

            dp[i][j]表示价值,i表示物品,j表示背包当前容量。例如:dp[1][0],容量为0的时候,我拿第一个物品,它的最大价值为多少。

            再者,在计算的时候,只跟前一层有关,不用把整个计算的过程都计算下来

    初始化二维矩阵的细节

    python生成矩阵为何[[0 for i in range(n)] for j in range(m)]而不能[[0]*n]*m

    python生成矩阵,使用[[0]*n]*m,我们会发现,当改变其中某一个元素时,整列数据都会发生改变,而使用[[0 for i in range(n)] for j in range(m)]才可以生成正常的矩阵。

    这是因为,list是可变元素,而int是不可变元素,对于list存储采用指针,引用型变量,改变矩阵其中某一个元素值,导致所有行的这个位置的元素都会改变。下面具体分析:

    Python列表和C语言数组不同,并不是存的实在的值,而是存放的只想其他实例的指针。所以也就能够理解 为什么python列表里里面什么东西都可以放进去而不需要考虑类型了。

     [[0]*2]*2的存储形式

    1. ls = [[0]*2]*2
    2. ls[0][0] = 1
    3. print(ls)

    [[0 for i in range(3)] for j in range(3)]的存储形式

    1. ls = [[0 for i in range(3)] for j in range(3)]
    2. print(ls)

    [0 for i in range(3) for j in range(3)]的存储形式

    1. ls = [0 for i in range(3) for j in range(3)]
    2. print(ls)

     

    题解

    为什么要设置N+1次循环,因为我们是根据表格的方式理解的01背包问题,当背包可选择数量为0,或者背包的总容量为0是,背包里的价值都为0。

    1. if __name__=="__main__":
    2. N,V=map(int,input().split())
    3. v=[0 for i in range(N+1)]
    4. w=[0 for i in range(N+1)]
    5. dp=[[0 for i in range(V+1)] for j in range(N+1)]
    6. for i in range(1,N+1):
    7. v[i],w[i]=map(int,input().split())
    8. for i in range(1,N+1):
    9. for j in range(1,V+1):
    10. dp[i][j]=dp[i-1][j]
    11. if j>=v[i]:
    12. dp[i][j]=max(dp[i-1][j],dp[i-1][j-v[i]]+w[i])
    13. print(dp[N][V])

  • 相关阅读:
    如何找回删除的ps文件?误删ps文件恢复方法
    【2 操作系统的结构】
    帧内预测中的initPredIntraParams()函数 (负参考方向处在跑代码时再看一遍)
    最简单的SpringCloudStream集成Kafka教程
    Redis - 10、主从复制
    12.Oracle的索引
    优雅而高效——立即执行函数表达式()();
    .Net 7内容汇总(2)--原始字符串
    分布式消息系统Kafka解析
    请求头Authorization
  • 原文地址:https://blog.csdn.net/llf000000/article/details/127699905
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号