- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
P=NP 是否可能是整个计算机科学中最著名的问题。这是什么意思?为什么这么有趣?
哦,为了获得额外的分数,请发布该陈述的真实性或虚假性的证明。 :)
最佳答案
P代表多项式时间。 NP 代表非确定性多项式时间。
定义:
多项式时间意味着算法的复杂度为 O(n^k),其中 n 是数据的大小(例如要排序的列表中的元素数量) ,k 是一个常数。
复杂性是以所需操作数量来衡量的时间,作为数据项数量的函数。
操作是对特定任务有意义的基本操作。对于排序来说,基本操作就是比较。对于矩阵乘法,基本运算是两个数字的乘法。
现在的问题是,确定性与非确定性意味着什么?有一个抽象的计算模型,一个称为图灵机(TM)的假想计算机。该机器具有有限数量的状态和无限的磁带,磁带具有离散的单元,可以在其中写入和读取有限的符号集。在任何给定时间,TM 都处于其中一种状态,并且它正在查看磁带上的特定单元。根据从该单元读取的内容,它可以将新符号写入该单元,将磁带向前或向后移动一个单元,然后进入不同的状态。这称为状态转换。令人惊讶的是,通过仔细构建状态和转换,您可以设计一个 TM,它相当于任何可以编写的计算机程序。这就是为什么它被用作理论模型来证明计算机可以做什么和不能做什么。
这里我们关心两种类型的 TM:确定性和非确定性。对于从磁带上读取的每个符号,确定性 TM 仅具有从每个状态的一次转换。一个非确定性 TM 可能有几个这样的转变,即。 e.它能够同时检查多种可能性。这有点像生成多个线程。不同之处在于,非确定性 TM 可以根据需要生成任意数量的此类“线程”,而在真实计算机上,一次只能执行特定数量的线程(等于 CPU 数量)。事实上,计算机基本上是具有有限磁带的确定性TM。另一方面,非确定性 TM 无法在物理上实现,除非使用量子计算机。
已经证明,任何可以用非确定性 TM 解决的问题都可以用确定性 TM 解决。不过,尚不清楚需要多长时间。语句 P=NP 意味着如果一个问题在非确定性 TM 上需要多项式时间,那么我们可以构建一个确定性 TM,它也可以在多项式时间内解决相同的问题。到目前为止,没有人能够证明它可以做到,但也没有人能够证明它不能做到。
NP完全问题是指一个NP问题X,使得任何NP问题Y都可以通过多项式约简化简为X。这意味着,如果有人提出了 NP 完全问题的多项式时间解决方案,那么这也将为任何 NP 问题提供多项式时间解决方案。这样就证明P=NP。相反,如果有人要证明 P!=NP,那么我们就可以确定在传统计算机上无法在多项式时间内解决 NP 问题。
NP 完全问题的一个例子是找到一个真值赋值问题,该赋值使包含 n 个变量的 bool 表达式为 true。
目前在实践中,任何在非确定性 TM 上需要多项式时间的问题只能在确定性 TM 或传统计算机上以指数时间完成。
例如,解决真值分配问题的唯一方法是尝试 2^n 种可能性。
关于computer-science - "P=NP?"是什么?为什么这是一个如此著名的问题?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/111307/
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 4年前关闭。 Improve thi
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 6 年前。 Improve this qu
我有一个关于车床的非常简单的问题。 如果它采取的第一个 Action 包括倒带,它会向后移动超过起点,还是这是一种特殊情况,它会留在起点吗? 最佳答案 这实际上取决于您使用的是哪种形式主义。一些形式主
我正在关注这个博客 http://www.quuxlabs.com/blog/2010/09/matrix-factorization-a-simple-tutorial-and-implementa
我正在尝试在 Kaggle Iowa 住房数据集上训练 LightGBM 模型,我编写了一个小脚本来随机尝试给定范围内的不同参数。我不确定我的代码有什么问题,但脚本使用不同的参数返回相同的分数,这是不
查找图形外边缘的最佳方法是什么? 例如,这张图上的红色边: 我不知道这个算法有没有名字。这个名字足以帮助我在 Google 上找到一些东西。 最佳答案 我希望我没有误解这个问题,但我认为没有答案,除非
我正在回答一些与虚拟内存相关的问题,并希望得到一些帮助来澄清或确认我对这些东西是如何完成的理解。 问题如下: Given a byte-addressable system with 32 bit w
我知道算法是一种有效的方法,表示为用于计算函数的定义明确的指令的有限列表。但是我们如何将它与逻辑区分开来? 最佳答案 哇,你的问题带我去旅行,我发现了一些东西!这可能不能作为答案,但将其放在这里作为引
关闭。这个问题是opinion-based .它目前不接受答案。 想改善这个问题吗?更新问题,以便可以通过 editing this post 用事实和引文回答问题. 4年前关闭。 Improve t
您如何评价出版物?我目前正在寻找 CS 研究主题并阅读各种论文。我在阅读论文时的困境通常是 - 在这个主题上继续研究真的值得吗? 研究影响的指标是什么? 顺便说一句,我目前对 - 活性分析感兴趣。你怎
根据我的教科书,L1 = A* - L1 的补码就是正则语言,只要 L1 是正则语言。 A* 不也包括上下文无关语言、上下文敏感语言和递归可枚举语言吗? A*-L1 也会包括所有这些,不是吗?那怎么能
我正在开发用户收集标签的 Web 应用程序。我需要根据用户标签的相似性为用户创建一个建议列表。 例如,当用户登录系统时,系统获取他的标签并在用户的数据库中搜索这些标签并显示具有相似标签的用户。例如如果
假设存在图灵机 M1、M2、M3,它们识别的语言分别是 L(M1)、L(M2) 和 L(M3)。以下语言 L = {(M1, M2, M3) : L(M1), L(M2), and L(M3) 不相等
我现在正在学习一个编译器类,我们正处于必须构建一个 CFG 以实现优化的地步。我不知道的一件事是一个程序有多少个 CFG?我见过的每个示例似乎都是一个简单代码段的 CGF。因此,如果您有一个具有三个功
关闭。这个问题是off-topic .它目前不接受答案。 想改善这个问题吗? Update the question所以它是 on-topic对于堆栈溢出。 9年前关闭。 Improve this q
我正在撰写有关计算机科学主题的相当长的专着。但是,我通常发现自己必须用数学术语写一些计算机科学概念,这对我来说很困难。例如,说我想编写一个for循环或void函数。我大部分时间都去我的Knuth或Co
堆栈在微处理器中的作用是什么? 最佳答案 堆栈主要在函数调用期间使用,但根据语言和编程级别,它可用于临时存储处理器寄存器数据或其他变量。 此外,当使用递归函数将部分数据存储在堆栈中并再次调用自己时,堆
到目前为止,我想出的最好的方法是卡片目录包含有关如何 cooking 不同类型食物的说明。它不包含有关如何 cooking 食物的信息,也不包含 cooking 食物本身的说明,但它可以为您指明位于其
我是一名 CS 大二学生,我想用电子学习度过我的暑假。周围有很多公开类(class),但我不知道从哪里开始或如何进行。 编辑:感谢您的建议,但我真正的问题是我无法选择我应该参加哪个特定的讲座。 最佳答
我对数据科学还很陌生。我正在研究使用基于产品编号和商店编号作为预测变量的线性回归来预测销售需求的用例。可以有许多具有数值的商店和产品。如果这些变量/预测变量的值是数字的、无界的并且在不同的尺度上,我是
我是一名优秀的程序员,十分优秀!