- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
考虑以下典型背包问题的输入。
V = [10,8,12]
W = [2,3,7]
i = 1,2,3
C = 10
我尝试使用记忆化递归来解决这个示例,但没有发现重叠的子问题。
递归过程的签名:
knapsack(int c, int i)
最初称为knapsack(10,1)
解题方法如https://www.youtube.com/watch?v=6h6Fi6AQiRM中所述。和 https://www.youtube.com/watch?v=ocZMDMZwhCY .
动态规划如何帮助降低这种背包样本的时间复杂度?如果它不能帮助提高这种情况的时间复杂度,那么 DP 解决方案的最坏情况复杂度也与基于回溯搜索,即 2 的 n 次方[忽略剪枝,就好像剪枝应用了一样,那么解决方案的复杂性将降低,而且 DP 也不会比非内存递归解决方案更好]
** 上面的示例中是否真的缺少子问题的重叠,或者我遗漏了什么?**
最佳答案
DP 对您的特定问题实例完全没有帮助。但总的来说,即在所有可能的输入实例中,它永远不会解决比纯递归更多的子问题,而且在许多情况下它解决的要少得多。 这就是 DP 很好的原因。
所有你的 DP 公式保证它可以通过解决最多 n(c+1)
个子问题来解决问题的任何实例,事实上它这样做是为了您的示例:此处 n
= 3 和 c
= 10,它通过解决 14 <= 33 个子问题(包括原始问题)来解决问题。
同样,纯递归解决方案保证它可以通过解决最多 2^n
个子问题来解决问题的任何实例。
您似乎认为 DP 算法应该比递归算法更快地解决每个问题实例,但事实并非如此,而且没有人提出这种说法。存在没有重叠子问题的实例(如您的实例),对于这些实例,DP 使用与递归解决方案完全相同数量的子问题来解决问题。这并没有说明这两种算法的行为一般。一般而言,DP 最多使用与递归解决方案一样多的子问题来解决每个问题,有时甚至更少——因为确实存在递归算法需要多次解决相同子问题的问题实例。
简而言之:DP 永远不会比递归差,并且在最坏的情况下优于递归。这并不意味着它在每个实例上都更好。
关于algorithm - 如果子问题 [0/1 knapsack] 没有重叠,DP 如何提供帮助,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39026436/
我学过这两种DP方式,现在很迷茫。不同情况下我们如何选择?而且我发现在大多数情况下,自上而下对我来说更自然。谁能告诉我如何做出选择。 PS:这篇文章我看过older post但仍然感到困惑。需要帮忙。
我在想是否有某种通用的方法可以将自上而下的动态编程转换为自下而上的编程。 我们能否想出某种机制来提供正式的方式,通过这种方式我们可以将自上而下的 DP 转换为自下而上的 DP。 注意:我是动态规划的初
在我的 xml 中,我在 TextView 上有这个: android:textSize="18dp"(是的,我知道 dp 不适合文本,但这不是重点) 我还有其他一些以编程方式创建的 TextView
假设我正在为屏幕尺寸等于或大于 600dp 的设备开发不同的布局。我想使用 post android 3.2 资源限定符。我创建了一个名为 layout-sw600dp 的文件夹并将我的布局放在那里,
最近我在 https://leetcode.com/problems/palindrome-partitioning-ii/ 上遇到了这个问题: 给定一个字符串s,划分s使得划分的每个子串都是回文。
我已经尝试使用 admob 大约 4 个小时了,现在真的卡住了。我得到: Not enough space to show ad. Needs 320x50 dp, but only has 288
我正在尝试将可变数量的像素计算为与密度无关的像素,反之亦然。 这个公式 (px to dp): dp = (int)(px/(displayMetrics.densityDpi/160)); 不适用于
我正在从头开始创建一个 HTML 页面,并在其中动态放置值,然后将其显示在 WebView 中。 我正在尝试在 WebView(作为 HTML)中复制 ActionBar(出现在应用程序的其他 Act
我正在使用 the 4.17.37 of Bootstrap 3 Datepicker - eonasdan datepicker 我有一个正确显示的内联日期选择器,我只会使用天模式,所以我使用以下代
我正在尝试将智能横幅广告添加到我的 fragment 布局中,但我不断得到的是“没有足够的空间来展示广告。需要 320x50 dp,但只有 309x0 dp”。 这是我的 fragment 布局。
我在关于 http://developer.android.com/guide/practices/screens_support.html 的一些不幸的歧义中迷失了方向,而且我找不到澄清问题的 st
写在前面 $ DP $,是每个信息学竞赛选手所必会的算法,而 $ DP $ 中状态的转移又显得尤为关键。本文主要从状态的设计和转移入手,利用各种方法对朴素 $ DP $ 的时间复杂度和空间复杂度进行
我试图理解一种著名的正则表达式匹配 DP 算法。以防万一,人们不知道这是描述和算法。 '.' Matches any single character. '*' Matches zero or mor
注意:是的,我知道Android中还有其他处理按钮的方法,但这只是一个示例来说明我的问题(实际的按钮要复杂得多)。因此,请不要在为Android中的按钮提供其他解决方案时回信,我正在寻找PaintCo
Closed. This question needs to be more focused。它当前不接受答案。 想改善这个问题吗?更新问题,使其仅关注editing this post的一个问题。
我正在测试 Samsung Galaxy Note 3根据文档,它是 1080 x 1920 像素(~386 ppi 像素密度)。我想弄清楚 dp 中的屏幕宽度 是多少,以便我可以正确应用并检查 ne
所以我现在完全迷路了,当用户通过Accessibility -> Font size 将字体大小时设置为Huge 时,文本大小会破坏我的 UI,所以为了快速修复 我决定将所有文本大小更改为 dp 而不
更新:我发现了我的问题。我已经为不同的分辨率定义了单独的可绘制资源,但我不知道我必须为不同的屏幕尺寸创建不同的布局。我想我应该更全面地阅读“支持多屏幕”页面。遇到此问题的任何其他人,请阅读整个页面:
阅读这篇文章(http://developer.android.com/guide/practices/screens_support.html)后,我在 xml 文件中使用 dp 单元开发了一个完整
该问题需要计算特定成本的硬币变化次数。 例如,如果我有 50, 20, 10, 5, 1 的硬币值(value),我可以形成以下成本: 5 => (5), (11111), 这是2种方式。 10 =>
我是一名优秀的程序员,十分优秀!