首页 > 其他分享 >评估计算复杂性

评估计算复杂性

时间:2023-11-16 21:33:35浏览次数:34  
标签:拼图 多项式 复杂性 问题 时间 计算 解决方案 NP 评估

计算机科学评估计算复杂性,是看它消耗的资源,具体来说就是时间内存(空间)

基于时间和空间复杂性,我们有:\(NL ⊆ P ⊆ NP ⊆ PSPACE ⊆ EXPTIME ⊆ EXPSPACE\)
(其中 \(⊆\) 表示子集关系)。


图来自:https://en.wikipedia.org/wiki/Complexity_class

对上图和公式的解释:

NL 非确定性对数空间

NL(Nondeterministic Logarithmic space 非确定性对数空间):NL类的问题可以被非确定性图灵机在对数量级的空间内解决。这意味着解决这些问题所需的内存空间与输入大小的对数成正比。

参看: 对数的本质是把乘除法降维成加减法

P 多项式时间

P(Polynomial time 多项式时间):P类问题可以被确定性图灵机在多项式时间内解决,即解决这些问题所需的时间与输入大小的某个多项式成正比。

NP 非确定性多项式时间

NP(Nondeterministic Polynomial time 非确定性多项式时间):NP类问题的一个解决方案可以被非确定性图灵机在多项式时间内验证。

PSPACE 多项式空间

PSPACE(Polynomial space 多项式空间):PSPACE类问题可以在多项式量级的空间内解决,无论解决时间长短。

EXPTIME 指数时间

EXPTIME(Exponential time 指数时间):EXPTIME类问题可以在指数时间内解决,即解决这些问题所需的时间随输入大小的增加而极速增长。

EXPSPACE 指数空间

EXPSPACE(Exponential space 指数空间):EXPSPACE类问题可以在指数量级的空间内解决,即解决这些问题可能需要非常大量的内存空间。

这些类别之间的包含关系(⊆)表示每个类别都是随后类别的一个子集。例如,所有P类问题都是NP问题,但并非所有NP问题都是P类问题。这些关系帮助我们理解不同计算问题的复杂性程度以及它们之间的联系。

上面复杂度排序中,为啥空间比时间复杂?

通常,空间复杂性被认为是比时间复杂性更“基础”,因为即使有足够的时间,如果没有足够的空间存储必要的信息,问题也无法解决

图:“精卫填海”的神话场景插画,每次能携带的土石有限,时间无限的话,问题也难以解决。

对数,多项式,指数 三个层次

在计算复杂性理论中,对数、多项式和指数主要描述的是算法的运行时间或空间需求随输入大小的增长速度。这些术语形成了一种层次结构,从效率最高到最低:

对数(Logarithmic):对数增长表示算法的资源需求随输入大小增长得非常慢。例如,对数时间复杂度通常表现为 \(O(\log_{}{n} )\),意味着每当输入大小翻倍时,所需资源只增加一个固定量。

多项式(Polynomial):多项式增长是相对适中的。多项式时间复杂度如 \(O(n)\)、\(O(n^2)\) 或 \(O(n ^3)\) 等,表示资源需求随输入大小呈多项式关系增长。在实际应用中,多项式时间通常被视为可接受的效率。

指数(Exponential):指数增长意味着资源需求随输入大小极快增长。例如,指数时间复杂度可以是 \(O(2 ^n)\) 或 \(O(n!)\),这意味着即使输入大小稍微增加,所需的资源也会迅速变得巨大。


图:资源需求随输入大小增长速度

在算法和问题分类中,我们总是希望达到尽可能低的复杂性级别。

P问题 与 NP 问题

尽管NP问题的解决方案可以在多项式时间内被验证,但并不意味着这些解决方案总是可以在多项式时间内被找到。

P类问题的特点是它们的解决方案不仅可以被快速验证,而且可以被快速找到。

将P问题比作拼图的话,可以想象一个简单的拼图,比如一个只有几十块的儿童拼图。这种拼图即使没有提示,大多数人也可以在相对较短的时间内完成。在这个比喻中,完成拼图的过程就像找到P问题的解决方案,而且这个过程并不需要花费很长时间或非常复杂的思考。


图:P问题可比作只有几十块的儿童拼图

NP-完全 与 NP-困难

NP-完全问题的例子:旅行商问题(TSP):在物流和运输规划中,旅行商问题要求找到最短的路径,经过一系列城市并返回出发点。这个问题在现实世界中的应用包括货物配送、航线规划等。

NP-困难问题的例子:图着色问题:在网络设计、电子电路布局、调度问题中,图着色问题需要确定最少的颜色数目,以使图中任何两个相邻的顶点都不同色。这个问题在分配资源(如频率分配、教室调度)时特别有用。

理解NP-完全和NP-困难问题的区别,可以想象两个不同类型的难题:

NP-完全问题 (NP-Complete):想象你有一个非常复杂的拼图,比如一千片的拼图。如果有人给你一个拼好的图案,你可以相对容易地验证这个拼图是否正确。这就像NP-完全问题,一旦有了解决方案,验证它是正确的还是相对容易的。但是,实际上找到这个解决方案(即拼好这个复杂的拼图)是非常困难的。


图:有一千片的拼图

NP-困难问题 (NP-Hard):现在,想象你需要解决一个更难的问题,比如一个复杂的三维立体拼图。这个问题比普通的拼图难多了,而且即使有人给你一个解决方案,验证这个解决方案是否正确也可能非常困难。这就是NP-困难问题,它们至少和NP-完全问题一样难,有时甚至更难,因为验证解决方案的正确性也可能是一个挑战。


图:有上万块的立体拼图

简而言之,NP-完全问题是那些解决方案难以找到但容易验证的问题,而NP-困难问题则是至少和NP-完全问题一样难,甚至可能在验证解决方案上也非常困难的问题。

NP 问题的使用场景

最常被提到的NP问题的特殊性在于其解决方案虽易于验证,却难以发现。在计算机科学和相关领域中非常重要,主要用于以下几个场景:

优化问题:许多NP问题是优化问题,即寻找最优解的问题。例如,在物流和运输中,旅行商问题(TSP)是一个典型的NP问题,它涉及寻找访问一系列城市并返回起点的最短路径。解决这类问题可以帮助公司节约成本和时间。

密码学:在密码学中,某些加密方法(如RSA算法)的安全性基于NP问题的难度。例如,一个大的整数的因数分解是一个NP问题。加密系统的安全性依赖于这类问题当前无法在多项式时间内有效解决。

计划和调度问题:在制造业、资源分配和项目管理中,需要解决各种调度问题,如机器调度、人员排班等,这些通常是NP难问题。

生物信息学和化学:在生物信息学中,比如在DNA序列分析、蛋白质结构预测中,很多问题都可以归类为NP问题。

网络设计:在网络理论中,比如互联网路由、社交网络分析中,找到最有效的网络连接方式往往是NP问题。

游戏理论和经济学:在分析经济模型或游戏策略时,确定最优策略往往涉及NP问题。

这些场景表明,尽管NP问题在理论上很难解决,但它们与实际生活和工业应用紧密相关。解决这些问题可以帮助提高效率、节约成本,甚至保护信息安全。虽然许多NP问题在理论上难以有效解决,但在实践中,人们常常通过近似算法、启发式方法或特定领域的技巧来寻找足够好的解决方案。

总结

计算复杂性理论是计算机科学的核心领域,专注于分析算法所需资源的时间和空间。

核心类别包括NL(非确定性对数空间)、P(多项式时间)、NP(非确定性多项式时间)、PSPACE(多项式空间)、EXPTIME(指数时间)和EXPSPACE(指数空间),这些类别揭示了计算问题的层级结构和相互关系。

最常被提到的NP问题的特殊性在于其解决方案虽易于验证,却难以发现,在计算机科学和相关领域中有广泛应用。

标签:拼图,多项式,复杂性,问题,时间,计算,解决方案,NP,评估
From: https://www.cnblogs.com/ghj1976/p/ping-gu-ji-suan-fu-za-xing.html

相关文章

  • 计算机组成原理:一、计算机系统概述
    参考视频:王道计算机考研计算机组成原理_哔哩哔哩_bilibili1.硬件的发展2.硬件的基本组成2.1冯诺依曼结构逻辑结构:特点:指令和数据以同等地位存储在存储器中,可以按照地址寻访。指令由操作码和地址码组成。以运算器为中心。这会带来一个问题:运算器本身是用来计算的......
  • 计算机组成原理之处理器(单周期)
    引言处理器的实现方式决定了时钟周期长度和CPI。实现方式有单周期与流水线,本篇谈谈单周期处理器。目前CPU的频率一般是3GHZ/4GHZ,但是频率是有极限值的,受cycletime影响基本的RISC-V实现存储指令:ld,sd算术逻辑指令:add,sub,and,or条件分支指令:beq实现每条指令的前两个步......
  • Java方法07:练习打一个计算器
    importjava.util.Scanner;publicclassDemo06{publicstaticvoidmain(String[]args){Scannerscanner=newScanner(System.in);Stringy="Y";while(y.equals("Y")){System.out.println(&quo......
  • 学期2023-2024-1 20231401 《计算机基础与程序设计》第八周学习总结
    学期2023-2024-120231401《计算机基础与程序设计》第八周学习总结作业信息这个作业属于哪个课程2023-2024-1-计算机基础与程序设计这个作业要求在哪里2023-2024-1计算机基础与程序设计第八周作业这个作业的目标《计算机科学概论》第9章《C语言程序设计》第7章并......
  • 【开源】基于Vue.js的计算机机房作业管理系统的设计和实现
    一、摘要1.1项目介绍基于Vue+SpringBoot+MySQL的计算机机房作业管理系统包含课程档案模块、课时档案模块、学生作业模块,还包含系统自带的用户管理、部门管理、角色管理、菜单管理、日志管理、数据字典管理、文件管理、图表展示等基础模块,计算机机房作业管理系统基于角色的访问控制......
  • 计算机程序的自动化
    计算机程序的自动化是指通过编写程序来实现特定任务的自动执行。自动化程序可以根据预定义的规则和条件,自动完成一系列操作,而无需人工干预。这样可以提高工作效率,减少人力成本,并减少错误发生的可能性。计算机程序的自动化可以应用于各个领域,例如:批量处理:自动化程序可以处理大......
  • 量子计算和量子通信技术
    一、定义量子计算和量子通信技术是一种基于量子力学原理的计算和通信技术,与传统计算和通信技术相比,具有更高的计算速度和更高的安全性。量子计算技术利用量子比特(qubit)替代传统计算机中的位(bit),利用量子态的叠加和纠缠等特性,实现更快速的计算。量子通信技术利用量子纠缠和量子密钥分......
  • 边缘计算物联网网关实现高效、实时、安全的物联网连接-天拓四方分享
    边缘计算物联网网关是一种能够将物联网设备连接到云端或互联网的硬件设备。它具有强大的数据处理和传输能力,可以在本地进行数据预处理,并通过网络将数据传输到云端或互联网。同时,它还支持多种通信协议和接口,可以与不同类型的物联网设备进行连接。随着物联网(IoT)设备的不断增加,如何实......
  • 计算机图形:计算法向量
    目录一元向量值函数及其导数一元向量值函数概念一元值函数的导数空间曲线的切线和法平面曲面的切平面与法线示例:求椭球体表面法向量参考一元向量值函数及其导数一元向量值函数概念已知空间曲线Γ(大写的γ)参数方程:\[\tag{1}\begin{cases}x=\varphi(t),\\y=\psi(t),t\in[\al......
  • 1-1 计算机基础和py环境搭建
    ​1.计算机基础1.1基本概念计算机组成:计算机是由多个硬件组合而成的东西,常见的硬件有:CPU、硬盘、内存、网卡、显示器、机箱、电源等等但单纯地组合并不能协作操作系统:用于协调计算机各个硬件,让硬件之间进行协同工作,以完成某个目标常见的操作系统:windows-xp\win7\win1......