码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 优先队列式广度优先搜索


    一 点睛

    优先队列以当前节点的上界为优先级,把普通队列改成优先队列,这样就得到了优先队列式分支限界法。

    二 算法设计

    优先级定义为活节点代表的部分解所描述的已装入物品的上界,上界越大,优先级越高。活节点的价值上界 up=活节点的 cp + 剩余物品装满背包剩余容量的最大价值 rp'。

    约束条件:cw+w[i]<=W

    限界条件:up=cp+rp'>=bestp

    三 图解背包问题

    有一个背包和 4 个物品,每个物品的重量和价值都如下图所示,背包的容量 W=10,求在不超过背包容量的前提下,把哪些物品放入背包才能获得最大价值。

    1 初始化

    sumw 和 sumv 分别用来统计所有物品的总重量和总价值。sumw = 13,sumv =18,sumw>W,因此不能全部装完,需要搜索求解。

    2 按价值重量比非递增排序

    排序后的结果见下图

    3 创建根节点 A

    4 扩展节点 A

    5 扩展节点 B

    6 扩展节点 D

    7 扩展节点 F

    8 扩展节点 G

    队头元素 G 出队,该节点的 up>=bestp,满足限界条件,可以扩展。t=5,已经处理完毕,bestp=cp=15,是最优解,解向量是 x[]=(1,1,1,0)。注意:虽然解是(1,1,1,0),但对应的物品原来的序号是1、4、3。节点 G 出队。

    9 队头元素 C 出队

    该节点的 up

    10 队头元素 E 出队

    该节点的 up

    11 队列为空,算法结束

  • 相关阅读:
    【Python编程】四、python字符串
    internship:用于类型判断的工具类编写
    自动化测试转型过程中遇到的困难,如何去克服
    c++实现简单股票买入和撤销功能(demo)
    mongodb基本操作命令
    ES5.6.4安装elasticdump实现备份
    【科技素养】蓝桥杯STEMA 科技素养组模拟练习试卷D
    leetcode第321场周赛
    嵌入式Linux驱动开发 01:基础开发与使用
    django表单的使用说明
  • 原文地址:https://blog.csdn.net/chengqiuming/article/details/126436535
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号