当前位置: 首页 > 面试题库 >

什么是计算机科学中的NP-complete?

贲功
2023-03-14
问题内容

什么是NP完全问题?为什么它在计算机科学中如此重要?


问题答案:

NP 代表 非确定性 多项式时间。

这意味着可以使用非确定性图灵机(类似于常规图灵机,但还包括非确定性“选择”功能)在多项式时间内解决问题。基本上,解决方案必须 可以 在聚合时间内进行
测试 。如果是这样,并且可以使用输入经过修改的给定问题来解决已知的NP问题(可以将NP问题 简化 为给定问题),那么该问题就可以解决NP问题。

要解决NP完全问题,最主要的事情是无法以任何已知的方式在多项式时间内解决它。NP-Hard / NP-
Complete是一种显示某些类型的问题在现实时间内无法解决的方法。

编辑:正如其他人指出的那样,通常有NP-
Complete问题的近似解决方案。在这种情况下,近似解通常使用特殊符号给出近似边界,该近似符告诉我们近似的接近程度。



 类似资料:
  • 1.3.什么是计算机科学 计算机科学往往难以定义。这可能是由于在名称中不幸使用了“计算机”一词。正如你可能知道的,计算机科学不仅仅是计算机的研究。虽然计算机作为一个工具在学科中发挥重要的支持作用,但它们只是工具。 计算机科学是对问题,解决问题以及解决问题过程中产生的解决方案的研究。给定一个问题,计算机科学家的目标是开发一个算法,一系列的指令列表,用于解决可能出现的问题的任何实例。算法遵循它有限的过

  • 本书全面而详细地阐述了计算机科学的理论基础,从抽象概念的机械化到各种数据模型的建立,用算法、数据抽象等核心思想贯穿各个主题,很好地兼顾了学科广度和主题深度,帮助读者培养计算机领域的大局观,学习真正的计算机科学。

  • 计算机(computer)是能以人的几百万甚至几十亿倍速度进行计算并作出逻辑判断的设备。例如今天的许多个人计算机每秒钟可以进行几亿次加法运算。操作台式计算器的人要几十年才能算出的数值,强大的个人计算机只要一秒钟即可计算完毕(注意:你怎么知道这个人加对了没有?你怎么知道计算机做得是否正确?)。 如今最快的超级计算机(supercomputer)每秒钟可以进行几干亿次加法运算,是成百上千的人花一整年时

  • Python 在科学计算上的应用非常广泛,包括数学、统计学、图形学……等等, 也是科学计算领域的首选编程语言之一。 这一部分的文章主要是介绍 Python 在科学计算领域常用的库,以及科学计算在日常中可能的实际用例。 常用库介绍 IPython 和 Jupyter Notebook NumPy NumPy 是 Python 科学计算生态系统的基础,提供了多维数组操作、线性代数运算、傅立叶变换等 多

  • 本文向大家介绍什么是计算机网络中的MIME?,包括了什么是计算机网络中的MIME?的使用技巧和注意事项,需要的朋友参考一下 MIME表示多用途Internet邮件扩展。它是对Internet电子邮件协议的改进,它使用户可以通过Internet交换几种数据文件,包括图像,音频和视频。 如果字符集中的文本不是美国信息交换标准码(ASCII),则需要MIME。实际上,所有人工编写的Internet电子邮

  • Numpy 是 Python 科学工具栈的基础。它的目的很简单:在一个内存块上实现针对多个条目(items)的高效操作。了解它的工作细节有助于有效的使用它的灵活性,使用有用的快捷方式,基于它构建新的工作。

  • Not to rain on everybody's parade, but there are three important ideas from computer science which are, frankly, wrong, and people are starting to notice. Ignore them at your peril. 不是想毁了每个人的三观,不过坦白说计

  • Jupyter Notebooks 你可以按[shift] + [Enter]或按菜单中的“播放”按钮来运行单元格。 在function(后面按[shift] + [tab],可以获得函数或对象的帮助。 你还可以通过执行function?获得帮助。 NumPy 数组 操作numpy数组是 Python 机器学习(或者,实际上是任何类型的科学计算)的重要部分。 对大多数人来说,这可能是一个简短的回顾