- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我必须证明以下问题是 NP 完全问题,并且需要一些有关如何继续的有用提示。
问题:
我们正在研究 session 预订系统。输入是 n 个可能时间的列表以及 m 个列表(其中 m <= n),每个人一个列表,其中包含他们选择的可能 session 时间。对于每个可能的时间,还会给出一个优先级编号。对于 n 列表中的每个预订时间,还给出了成本。 (预订房间的费用)。算法应该分配时间,使得已预订者的组合优先级应尽可能小,而预订的总成本不应高于 M。
NP
所以首先要证明它在 NP 中,我们应该证明给定一个正确的解决方案,可以验证它确实是正确的。我想它应该验证成本低于 K 的阈值并且正确解决方案的优先级确实是最小的 - 这两者都可以在我假设的多项式时间内完成。我们遍历人员列表,断言每个人都有一个时间,将成本加到一个变量中,并在该列表的末尾断言成本低于 K。优先级可以用类似的方式处理我想?
NP 困难
然后为了证明它是 NP Hard,我可以使用背包问题,因为它们非常相似。输入 S、包的大小、重量为 w 和值(value)为 v 的项目列表以及目标 W,即目标值。我想很明显 S 可以与成本相关,而 W 可以与优先级相关?所以我们希望 S(大小)低于 S,即对于上述问题,我们有类似的条件,成本必须低于 K。那么 W,总值(value)通常应该超过 W,但在我们的例子中,我们希望它尽可能低,这似乎是可行的。
恐怕我在验证问题时走错了路。此外,减少显示它是 NP 硬的可能并不是所有的考虑。一些指示会非常有帮助!谢谢
最佳答案
NP
当你要证明问题是 NP 问题时,你必须先把你的问题变成一个决策问题。然后您可以在开始描述时以多项式时间验证您的证书。
NP 困难
您需要将背包问题转化为 session 问题。你走的路是对的,因为你正在将背包的大小和重量转化为 session 问题。计算出转换后,您必须验证它是否可以在多项式时间内完成。最后,您可以证明背包问题的解决方案是 session 问题的解决方案,反之亦然。
关于algorithm - 预订系统是 NP Complete,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41249683/
我有一个返回 future 的函数,该函数取决于要解决的回调结果: Future connectSocket(String email, String password, {Function o
我正在尝试链接两个返回 Completable 的响应式调用在 android 上使用改造: val userRequest = ... val languageRequest = ... retur
我正在尝试将一些数据保存在数据库中。对于添加方法,我使用 Completable。在我保存一个实体 - 客户之后,我想保存一个天数列表,但只有在客户被保存之后。这是我现在的代码。 mDatabaseM
我是 RxJava 的新手,遇到了以下问题: 我有两个 Completable 对象来存储一些数据。我想触发第一个,然后仅在第一个成功完成后才启动第二个。对第二个 Completable 的调用应该被
我正在尝试从两个不同的文件中读取数据,一个是 csv 格式,另一个文件是 xml 数据。使用completeFuture 我正在尝试从两个文件异步读取数据。我收到类型转换错误。请让我知道我是否遵循正确
我有以下人员类别: class Person { String name; String city; public void setInfo(PersonInformation
我正在尝试这个: var notifications = $( "#notifications" ); notifications.fadeOut("slow") .complete(func
我发现 Bash shell 支持一种不同于“传统”自动完成的自动完成类型,所有可能性都列在下一行。 使用“传统的”自动完成,如果我键入 ch 然后按 Tab 键,我会得到如下信息: $ ch cha
我是 rxjava/rxkotlin/rxandroid 的初学者。 我需要按顺序处理三个不同的异步调用。问题是第一步返回 Single ,第二个Completable第三个又是Completable
默认情况下,在 TextMate 中按 Esc 会循环执行可能的补全(除了关闭对话框之外),这可能会在文档中放入不需要的字符,特别是如果您习惯于在大多数文本编辑器中使用 Esc 作为安全键的话。 (事
我知道 pull complete 在之后到达 download complete 在生命周期中,但我有兴趣了解它们之间的区别。我尝试在互联网上搜索,但找不到任何清楚解释这些差异的内容。 最佳答案 拉
以下代码似乎永远不会工作,因为组似乎没有终止,并且 takeLast() 不知道最后是什么: observableSequence .groupBy { $0.key } .map { gro
我是 ido-mode 的忠实粉丝,以至于我想用它来做 describe-function 之类的事情或 find-tag等等,而无需编写类似“我可以在 Emacs 中搜索标签的 ido-mode-s
我们什么时候应该使用 Completable.fromAction()我们什么时候应该使用 Completable.fromCallable()是否有特定的用例 从文档看来,两者都做同样的事情,很难注
我有以下gulpfile.js,我通过命令行执行gulp消息: var gulp = require('gulp'); gulp.task('message', function() { cons
我在我的 .vimrc 文件中设置了 omnifuc : setlocal omnifunc = javacomplete#complete 然后当我编辑任何文件时出现异常: E518: Unknow
我如何将 Single 链接到 Completable,以便在 Completable 完成时订阅它? repository.downloadUser() 是 Single。 根据调试,似乎此方法中的
在bash中,默认情况下,按Tab键将显示当前目录中的所有文件和目录。例如:。Cat a将显示类似aFile.txt apples.png aDirectory/的内容。如果您随后完成了a目录,它将显
在bash中,默认情况下,按Tab键将显示当前目录中的所有文件和目录。例如:。Cat a将显示类似aFile.txt apples.png aDirectory/的内容。如果您随后完成了a目录,它将显
我错过了什么?示例使用 min.js。 bundle.min.js 有更多代码,但我找不到该额外代码的描述...... https://getbootstrap.com/docs/4.0/gettin
我是一名优秀的程序员,十分优秀!