对于分支界限法的理解(补出门门票-week13,结对伙伴对我提的问题的答案)
- 首先我的结对伙伴给我提出了一个这样的问题:
 - 使用分支界限法求解“背包问题”的步骤。
 - 当时我是这样回答他的:
 - ub=v+(W-w)x(v(i+1)/w(i+1))
 - 这个问题我在课上也没有理解清楚,因为我不知道ub是怎么算出来的。。。(虽然公式给了我,但我还是不理解)所以我准备周五去问问小助教这个问题如何求解,问题答案将在这周博客内容里体现。
 - 我问过小助教之后,他从PPT下拉出来了备注(我居然忽略了备注)
 - 于是我就把电脑抱回去自己看了。
 
对于分支界限法的疑惑
- 1、ub是什么,为什么背包没装物品的时候ub可以是100,也可以是60?
 - 2、为什么当背包中只存在物品1的时候,ub是会发生改变的?
 
问题的答案(自己理解的)
- 1、ub是理论上的最优上界,就是我要放的东西(假如说是物品1)要把背包放满能值多少钱。
 - 那么为什么会等于100呢?物品1重量不是4吗?最多不是只能放两个ub=80吗?
 - 是的,没错,但我们这里说ub是理论上的最优上界。我们要考虑的仅仅是背包的容量还有物品的单价,不去考虑物品的总重量(40),只考虑单价的重量(10)。于是ub=10x10=100。
 - 那么为什么当我们不放物品1的时候ub=60呢?
 - 这就要用到公式了:ub=v+(W-w)x(v(i+1)/w(i+1))
 - 当我们不放物品1时,第二顺位要放的物品是物品2,所以公式中的v(i+1)就等于物品2的价值(42),w(i+1)就等于物品2的重量(7)。
 - 而因为我们什么东西也没有放。
 - 所以v=0,w=0,W还是不变等于10。
 - 所以当我们不放物品1时ub=10x6=60。
 - 2、当背包中只存在物品1时,ub之所以会变化是因为接下来要放的东西不同了。
 - 在ub=76的时候,背包中接下来要放的是物品2。
 - 也就是说,此时的v(i+1)=42、w(i+1)=7。
 - 但物品2的重量加上物品1的重量等于11,超过了背包容量(10)。所以我们接下来要放物品3。
 - 那么当我们要放物品3时,此时v(i+1)和w(i+1)已经不再是物品2的值了,而是v(i+1)等于物品3的v3=25、w(i+1)等于物品3的w3=5。
 - 所以此时公式应该是:40+(10-4)×5=70。
 
感想
- 其实PPT下面的备注说的已经非常的清楚,但是我还是希望我能用自己理解的方式写在博客中。
 - 而且我一开始真的没看懂PPT上面的备注······

 
对于分支界限法的理解(补出门门票-week13,结对伙伴对我提的问题的答案)的更多相关文章
- 对"构建之法“的理解和困惑
		
对"构建之法"的理解和困惑 本人"学沫沫"一个,对于之前的编程学习虽不大"感冒",但秉着对自己负责的态度进行了基础学习. ...
 - rt-thread中软件定时器组件超时界限的一点理解
		
@2019-01-15 [小记] 对 rt-thread 中的软件定时器组件中超时界限的一点理解 rt_thread_timer_entry(void *parameter)函数中if ((next_ ...
 - git的使用理解(分支合并的使用理解,多人编程的解决方案)
		
本文主要记录了对git日常使用的一些理解,主要是对git分支的一些感悟. git强大的版本控制系统,之前也使用过SVN,感觉上git对于多人开发的版本控制更加强大,特别是最近对git分支的使用,更是深 ...
 - 多元Huffman编码变形—回溯法
		
一.问题描述 描述 在一个操场的四周摆放着n堆石子.现要将石子有次序地合并成一堆.规定在合并过程中最多可以有m(k)次选k堆石子合并成新的一堆,2≤k≤n,合并的费用为新的一堆的石子数.试设计一个算法 ...
 - 数据结构(DataStructure)与算法(Algorithm)、STL应用
		
catalogue . 引论 . 数据结构的概念 . 逻辑结构实例 2.1 堆栈 2.2 队列 2.3 树形结构 二叉树 . 物理结构实例 3.1 链表 单向线性链表 单向循环链表 双向线性链表 双向 ...
 - 算法设计与分析基础 (Anany Levitin 著)
		
第1章 绪论 1.1 什么是算法 1.2 算法问题求解基础 1.2.1 理解问题 1.2.2 了解计算设备的性能 1.2.3 在精确解法和近似解法之间做出选择 1.2.4 算法的设计技术 1.2.5 ...
 - 启发式搜索技术A*
		
开篇 这篇文章介绍找最短路径的一种算法,它的字我比较喜欢:启发式搜索. 对于入门的好文章不多,而这篇文章就是为初学者而写的,很适合入门的一篇.文章定位:非专业性A*文章,很适合入门. 有图有真相,先给 ...
 - 基于分支限界法的旅行商问题(TSP)一
		
旅行推销员问题(英语:Travelling salesman problem, TSP)是这样一个问题:给定一系列城市和每对城市之间的距离,求解访问每一座城市一次并回到起始城市的最短回路.它是组合优化 ...
 - 利用分支限界法求解单源最短路(Dijkstra)问题
		
分支限界法定义:采用Best fist search算法,并使用剪枝函数的算法称为分支界限法. 分支限界法解释:按Best first的原则,有选择的在其child中进行扩展,从而舍弃不含有最优解的分 ...
 
随机推荐
- CF370 D  Memory and Scores
			
dp题 并运用了前缀和 我看题目提示中有fft 我想了下感觉复杂度不过关还是未解 #include<bits/stdc++.h> using namespace std; typedef ...
 - java暴力递归回溯算法
			
今天这个问题是我之前一直想解决的,还记得以前第一次上蓝桥杯的课的时候,也就是大一高数期中模拟考试那天,下午去上蓝桥杯课,遇到这道题,当时写了写,根本没有思路,然后就给大一的模拟考试去了.印象深刻啊,一 ...
 - day9(Hash、字典)
			
一.Hash 简介: Hash,一般被翻译成"散列",也有直接音译"哈希"的,就是把任意长度的输入,通过哈希算法,变换成固定长度的输出,输出的结果就叫做哈希值, ...
 - 凯撒密码加密解密--JAVA实现(基础)
			
凯撒密码一种代换密码,据说凯撒是率先使用加密函的古代将领之一,因此这种加密方法被称为恺撒密码.凯撒密码的基本思想是:通过把字母移动一定的位数来实现加密和解密.明文中的所有字母都在字母表上向后(或向前) ...
 - 如何在Win10下安装MySQL 5.7绿色版
			
一.背景 系统升级到Win10后准备在本地搭建一个MySQL环境,用于研究学习.在网上找了很多其他人写的经验总结,Step by step的做,不断的遇到问题,没有成功. 最后老老实实的去读Mysql ...
 - SpringMVC【开发Controller】详解
			
前言 本文主要是讲解在Controller中的开发,主要的知识点有如下: 编码过滤器 使用注解开发 注解@RequestMapping详解 业务方法接收参数 字符串转日期 重定向和转发 返回JSON ...
 - NancyFX 第十一章 Bootstrapping
			
本章我们将深入Nancy的内部,对Nancy的内部组件进行修改和调整. 那什么是bootstrap哪?字典里是这么介绍的: 一般而言,处于引导中(bootstrapping)是在终端用户可以使用之前开 ...
 - NancyFX 第五章 Nancy 路由
			
在Nancy中,最为神奇的莫过于路由了,定义路由模块是构成Nancy应用的骨架.在Nancy中定义路由,和在 ASP.NET MVC那些类似的框架中有着非常大的区别. 以 ASP.NET MVC 为例 ...
 - HandsonTable日期控件的汉化
			
由于项目的需要,想把HandsonTable自带的日期中英文替换成中文.其实这个不难,只要在库文件中替换下就可以了,替换的效果对比如下: 如果有需要的同学,可以在此处下载 By QJL
 - java序列化浅谈
			
首先大家进来第一个疑问肯定是"什么是序列化?为什么要使用序列化?怎么实现一个简单的序列化案例?" 1.序列化就是把对象以一种规范的二进制形式存在内存中,另一边以反序列化方式获取: ...