当前位置: 首页 > news >正文

计算机考研之数据结构:P 问题和 NP 问题

在算法的时间复杂度估算中,通常教材和题目中的估算结果包括: O ( 1 ) , O ( log ⁡ n ) , O ( n ) , O ( n ) , O ( n log ⁡ n ) , O ( n 2 ) , O ( n 3 ) , O ( log ⁡ log ⁡ n ) O(1),O(\log{n}),O(\sqrt{n}),O(n),O(n\log{n}),O(n^2),O(n^3),O(\log\log n) O(1),O(logn),O(n ),O(n),O(nlogn),O(n2),O(n3),O(loglogn) 等,这些时间复杂度之间,存在如下定性的大小关系:
O ( 1 ) < O ( log ⁡ log ⁡ n ) < O ( log ⁡ n ) < O ( n ) < O ( n ) < O ( n log ⁡ n ) < O ( n 2 ) < O ( n 3 ) O(1)\lt O(\log\log{n})\lt O(\log{n})\lt O(\sqrt{n})\lt O(n)\lt O(n\log{n})\lt O(n^2)\lt O(n^3) O(1)<O(loglogn)<O(logn)<O(n )<O(n)<O(nlogn)<O(n2)<O(n3)
其中, O ( log ⁡ log ⁡ n ) , O ( log ⁡ n ) , O ( n ) , O ( n ) , O ( n log ⁡ n ) , O ( n 2 ) , O ( n 3 ) O(\log\log{n}), O(\log{n}), O(\sqrt{n}), O(n), O(n\log{n}), O(n^2), O(n^3) O(loglogn),O(logn),O(n ),O(n),O(nlogn),O(n2),O(n3) 等称为多项式时间复杂度(Polynomial Time Complexity),可以统一表示为 O ( f ( n ) ) O(f(n)) O(f(n)) ,且 f ( n ) f(n) f(n) 为多项式。

如果从纯粹应付考试的角度来讲,知道上述内容就足够了。但是,如果作为一个未来的开发者,不能将仅仅以“考什么学什么”来要求自己,特别是在基础知识复习的时候,务必要多了解一些。本文即是对一般辅导资料的补充。

在算法复杂度理论中,多项式级的运行时间往往被认为是可接受的。某问题若可以用多项式复杂度的算法求解,则称该问题是可有效求解的,或者易解的。这样的问题也称为 P 问题(P,即 Polynomial,多项式)。

除了 P 问题之外,还有另外一类问题,只能用指数时间复杂度(Exponential Time Complexity)的算法求解,称为 NP 问题(即 Non-deterministic Polynomial Problem,非确定多项式问题),例如,计算斐波那契数列的一种算法的时间复杂度就是指数时间复杂度,即 T ( n ) = O ( a n ) , ( a > 1 ) T(n)=O(a^n),(a\gt1) T(n)=O(an),(a>1) 。一般认为,指数时间复杂度的算法无法真正应用于实际问题中,这类算法不是有效的算法。

P 问题

P 问题是指能够在多项式时间内解决的问题。这里的 “解决” 意味着存在一个算法,对于该问题的任何规模为 n n n 的输入实例,都能在 O ( n k ) O(n^k) O(nk) k k k 为常数)的时间内给出正确的答案。

例如,判断一个整数是否为偶数就是一个 P 问题。我们可以设计一个简单的算法,只需要检查该整数的最后一位是否为 0、2、4、6 或 8,这个操作的时间复杂度为 O ( 1 ) O(1) O(1) ,属于多项式时间复杂度。比如判断整数 1234,只看最后一位 4,就能在极短时间内得出它是偶数的结论。再如,计算两个矩阵的乘积也是一个 P 问题。通过标准的矩阵乘法算法,对于两个 n × n n \times n n×n 的矩阵,其时间复杂度为 O ( n 3 ) O(n^3) O(n3) ,同样在多项式时间内可解。像 3 × 3 3\times3 3×3 矩阵相乘,按照算法步骤就能在符合 O ( n 3 ) O(n^3) O(n3) 时间复杂度的情况下得出结果。

计算一组数字的平均值也是 P 问题。假设有 n n n 个数字,先将这 n n n 个数字相加,时间复杂度为 O ( n ) O(n) O(n) ,再除以 n n n ,这一步时间复杂度为 O ( 1 ) O(1) O(1) ,整体时间复杂度为 O ( n ) O(n) O(n) ,属于多项式时间复杂度。例如有 5 个数字 1、2、3、4、5,相加操作执行 5 次,然后除以 5,很快就能得出平均值 3。

P 问题集合涵盖了大量我们日常遇到且能够有效解决的问题。这些问题可以通过现有的计算资源和算法,在合理的时间范围内得到解答。

NP 问题

NP 即非确定性多项式(non-deterministic polynomial)时间,NP 问题是指可以在多项式时间内通过非确定性算法验证其解是否正确的问题。这里的 “非确定性算法” 可以理解为在算法执行的某些步骤中,允许出现不确定的选择,并且如果一个问题存在至少一种可能的解能够在多项式时间内被验证,那么这个问题就属于 NP 问题。

一个经典的 NP 问题例子是 “子集和问题”。给定一个整数集合 S S S 和一个目标整数 t t t ,判断是否存在 S S S 的一个子集,使得子集中所有元素的和等于 t t t 。假设我们得到了一个声称是该问题解的子集 S ′ S' S ,要验证这个解是否正确,只需要对 S ′ S' S 中的元素进行求和,然后检查和是否等于 t t t 。这个验证过程的时间复杂度与子集 S ′ S' S 的大小成正比,对于给定的输入规模(集合 S S S 的大小为 n n n ),验证时间是多项式时间 O ( n ) O(n) O(n) 。例如,集合 S = { 1 , 3 , 5 , 7 , 9 } S = \{1, 3, 5, 7, 9\} S={1,3,5,7,9} ,目标 t = 15 t = 15 t=15 ,若给出一个解子集 S ′ = { 1 , 5 , 9 } S' = \{1, 5, 9\} S={1,5,9} ,我们将 S ′ S' S 中元素相加 1 + 5 + 9 = 15 1 + 5 + 9 = 15 1+5+9=15 ,与 t t t 相等,验证了该解正确,且这个验证过程很快,时间复杂度符合 O ( n ) O(n) O(n) ,这里 n n n 为子集 S ′ S' S 的元素个数 3。然而,找到这个解本身可能并不容易,目前没有已知的多项式时间算法能够直接找出满足条件的子集。

另一个著名的 NP 问题是 “旅行商问题”。假设有一个旅行商需要访问 n n n 个城市,每个城市之间都有一定的距离,旅行商需要找到一条最短的路径,使得他能够遍历所有城市且每个城市只访问一次并最终回到出发城市。如果给定一条路径,我们可以在多项式时间内计算出这条路径的总长度,从而验证它是否是最短路径的候选解。例如有 4 个城市 A、B、C、D,假设各城市间距离为:A 到 B 为 5,A 到 C 为 3,A 到 D 为 7,B 到 C 为 2,B 到 D 为 4,C 到 D 为 6。若给定一条路径 A - B - C - D - A,计算路径长度为 5 + 2 + 6 + 7 = 20 5 + 2 + 6 + 7 = 20 5+2+6+7=20 ,计算过程简单,时间复杂度低。但要从所有可能的路径组合中找到最短路径,计算量随着城市数量 n n n 的增加而呈指数级增长,目前还没有找到多项式时间的求解算法。

“哈密顿回路问题” 也是 NP 问题。对于一个给定的图,判断是否存在一条路径,从某个顶点出发,不重复地经过图中每个顶点恰好一次,最后回到起始顶点。若给出一条声称满足条件的路径,验证这条路径是否真的遍历了所有顶点且不重复,只需要依次检查路径上的顶点,时间复杂度与路径长度成正比,属于多项式时间。例如在一个有 6 个顶点的图中,给定路径 v 1 − v 2 − v 3 − v 4 − v 5 − v 6 − v 1 v_1 - v_2 - v_3 - v_4 - v_5 - v_6 - v_1 v1v2v3v4v5v6v1 ,逐个检查顶点是否符合要求,能快速完成验证,但要找到这样一条回路却非常困难,没有多项式时间算法。

P 问题与 NP 问题的关系

P 问题和 NP 问题之间的关系是计算机科学领域中一个尚未完全解决的重大问题,即 “P 是否等于 NP”。直观上看,P 问题集合是 NP 问题集合的一个子集,因为如果一个问题能够在多项式时间内被解决,那么它的解必然可以在多项式时间内被验证。也就是说,所有的 P 问题都是 NP 问题。然而,目前还不清楚是否所有的 NP 问题也都是 P 问题,即是否存在一个通用的方法,能够将所有 NP 问题在多项式时间内转化为 P 问题来求解。

如果 P = NP,那么这意味着许多目前被认为难以解决的问题(如旅行商问题、子集和问题等)实际上都存在多项式时间的求解算法,这将对计算机科学以及众多依赖计算的领域产生革命性的影响。但目前为止,尽管经过了大量的研究,还没有人能够证明 P = NP,同时也没有人能够证明 P ≠ NP。

多项式时间复杂度、P 问题和 NP 问题是计算机科学中理解算法效率和问题难度的关键概念。多项式时间复杂度为我们评估算法性能提供了重要依据,P 问题代表了可有效求解的问题类别,NP 问题则涵盖了那些解的验证相对容易但求解可能困难的问题。而 P 与 NP 之间的关系,作为计算机科学领域的核心未解之谜,持续吸引着众多研究者不断探索和研究。

相关文章:

计算机考研之数据结构:P 问题和 NP 问题

在算法的时间复杂度估算中&#xff0c;通常教材和题目中的估算结果包括&#xff1a; O ( 1 ) , O ( log ⁡ n ) , O ( n ) , O ( n ) , O ( n log ⁡ n ) , O ( n 2 ) , O ( n 3 ) , O ( log ⁡ log ⁡ n ) O(1),O(\log{n}),O(\sqrt{n}),O(n),O(n\log{n}),O(n^2),O(n^3),O(\log…...

新数据结构(13)——I/O

字符流 字符输入流&#xff08;Reader&#xff09; 字符输入流用于从数据源&#xff08;如文件、字符串等&#xff09;读取字符数据。Reader 是所有字符输入流的抽象基类。 常用实现类 FileReader 用于从文件中读取字符数据。 InputStreamReader 将字节流转换为字符流&…...

PySide6学习专栏(四):用多线程完成复杂计算任务

如果计程序中要处理一个非常庞大的数据集中的数据&#xff0c;且数据处理计算很复杂&#xff0c;造成数据处理占用大量时间和CPU资源&#xff0c;如果不用多线程&#xff0c;仅在主进程中来处理数据&#xff0c;将会使整个程序卡死&#xff0c;必须采用多线程来处理这些数据是唯…...

Python多线程编程理解面试题解析

一、多线程介绍 Python 的多线程是一种实现并发编程的方式&#xff0c;允许程序同时执行多个任务。然而&#xff0c;由于 Python 的全局解释器锁&#xff08;GIL&#xff09;的存在&#xff0c;多线程在某些场景下可能无法充分利用多核 CPU 的性能。以下是对 Python 多线程的理…...

Flutter - 初体验

项目文件目录结构介绍 注&#xff1a;创建 Flutter 项目名称不要包含特殊字符&#xff0c;不要使用驼峰标识 // TODO 开发中运行一个 Flutter 三种启动方式 Run 冷启动从零开始启动Hot Reload 热重载执行 build 方法Hot Restart 热重启重新运行整个 APP 先看效果&#xff0c…...

使用最广泛的Web应用架构

目前互联网中没有一种绝对使用最广泛的Web应用架构&#xff0c;不同的架构在不同的场景和企业中都有广泛应用&#xff0c;但微服务架构和Serverless架构是当前较为主流和广泛使用的架构。以下是对这两种架构的具体分析&#xff1a; 微服务架构 适用场景广泛 大型互联网公司&a…...

YOLOv11-ultralytics-8.3.67部分代码阅读笔记-split_dota.py

split_dota.py ultralytics\data\split_dota.py 目录 split_dota.py 1.所需的库和模块 2.def bbox_iof(polygon1, bbox2, eps1e-6): 3.def load_yolo_dota(data_root, split"train"): 4.def get_windows(im_size, crop_sizes(1024,), gaps(200,), im_rate_t…...

Unity shader glsl着色器特效之 模拟海面海浪效果

一个简单的海浪效果&#xff0c;通过波的叠加实现水面起伏的动效&#xff0c;根据波峰斜率来为浪花着色&#xff0c;再根据法线贴图和水花贴图来和调整uv的平滑移动来增强海浪移动的细节。如果需要更逼真的效果可以考虑在满足浪花触发的地方添加粒子系统 前置效果图 因为是很久…...

`AdminAdminDTO` 和 `userSession` 对象中的字段对应起来的表格

以下是将更正后的表格放在最前面的回答&#xff0c;表格包含序号列&#xff0c;合并了后端 AdminAdminDTO 和前端 userSession 的所有字段&#xff0c;并标注对方没有的字段。token 字段值用省略号&#xff08;...&#xff09;表示&#xff1a; 序号字段名AdminAdminDTO (后端…...

sqlserver查询内存使用情况的方法

查询 这个SQL查询用于获取当前数据库实例中各个数据库在缓冲池&#xff08;buffer pool&#xff09;中的数据页所占用的内存大小。 select isnull(db_name(database_id),ResourceDb) AS DatabaseName,CAST(COUNT(row_count) * 8.0 /(1024.0) AS DECIMAL(28,2)) AS [size (MB…...

rust笔记7-生命周期显式标注

Rust 的生命周期(Lifetimes)是 Rust 内存安全模型的核心部分,用于确保引用始终有效,避免悬垂引用(Dangling References)。下面我们从生命周期的设计出发点、标注语法以及在不同上下文中的应用(函数、方法、结构体、trait 等)来详细介绍。 1. 生命周期设计的出发点 Rus…...

SQL Server 导入Excel数据

1、选中指定要导入到哪个数据库&#xff0c;右键选择 》任务 》导入数据 2、数据源 选择Excel&#xff0c;点击 下一步(Next) 3、目前 选择OLE DB Provider &#xff0c;点击 下一步&#xff08;Next&#xff09; 4、默认 &#xff0c;点击 下一步&#xff08;Next&#xff09;…...

【笔记】LLM|Ubuntu22服务器极简本地部署DeepSeek+联网使用方式

2025/02/18说明&#xff1a;2月18日~2月20日是2024年度博客之星投票时间&#xff0c;走过路过可以帮忙点点投票吗&#xff1f;我想要前一百的实体证书&#xff0c;经过我严密的计算只要再拿到60票就稳了。一人可能会有多票&#xff0c;Thanks♪(&#xff65;ω&#xff65;)&am…...

【面试题】2025.02.19-前端面试题汇总

杭州三汇 1. 自我介绍 2. 你们前端项目为什么要用微前端&#xff1f; 减少由于程序更新导致的问题影响面积&#xff1b;缩小前端包体积&#xff0c;加快页面开发速度&#xff1b;便于统一多家医院某几个系统的程序一直&#xff1b; 3. 详细介绍一个项目&#xff0c;项目干什…...

小米AX3000T 路由器如何开启 SSH 安装 OpenWRT 系统,不需要降级 v1.0.91 (2025)

小米AX3000T 路由器如何开启 SSH 安装 OpenWRT 系统&#xff0c;不需要降级 v1.0.91 &#xff08;2025&#xff09; 本文内容需要你有一定的 Linux 操作基础&#xff0c;最好是程序员那种&#xff0c;英文水平足够用才行。一般人不需要使用这么复杂的路由器操作系统&#xff0c…...

火语言RPA--Excel插入空行

【组件功能】&#xff1a;在Excel内指定的位置插入空行 配置预览 配置说明 在第n行之前 支持T或# 填写添加插入第n行之前行号。 插入n行 支持T或# 插入多少行。 Sheet页名称 支持T或# Excel表格工作簿名称。 示例 Excel插入空行 描述 在第3行之后插入3行。 配置 输…...

具有整合各亚专科医学领域知识能力的AI智能体开发纲要(2025版)

整合各亚专科医学领域知识能力的AI代理的开发与研究 一、引言 1.1 研究背景 在科技飞速发展的当下,人工智能(AI)已成为推动各行业变革的关键力量,医疗领域也不例外。近年来,AI 在医疗行业的应用取得了显著进展,从医学影像诊断到疾病预测,从药物研发到个性化医疗,AI 技…...

【Java 优选算法】位运算

欢迎关注个人主页&#xff1a;逸狼 创造不易&#xff0c;可以点点赞吗~ 如有错误&#xff0c;欢迎指出~ 基础位运算符: &: 有 0 就是 0 | : 有 1 就是 1 ^ :相同为0,相异为1(无进位相加) 1.给一个数 n, 确定它的二进制表示中的第x位是 0 还是 1 . 使用公式(n >> x) &…...

细分数字货币钱包的不同种类

文章目录 一、中心化钱包1.1 中心化钱包架构1.2 中心化钱包业务细节流程 二、去中心化钱包(HD 钱包)2.1 去中心化钱包架构2.2 去中心化钱包细节业务流程 三、硬件钱包3.1 硬件钱包架构3.2 硬件钱包细节业务流程 四、MPC 托管钱包五、多签钱包 中心化钱包 &#xff1a;钱包私钥一…...

Nginx Embedded Variables 嵌入式变量解析(4)

Nginx Embedded Variables 嵌入式变量解析(4) 相关链接 nginx 嵌入式变量解析目录nginx 嵌入式变量全目录nginx 指令模块目录nginx 指令全目录 一、目录 1.1 变量目录 1.1.24 ngx_stream_core_module $binary_remote_addr $bytes_received $bytes_sent $connection $hos…...

大型活动交通拥堵治理的视觉算法应用

大型活动下智慧交通的视觉分析应用 一、背景与挑战 大型活动&#xff08;如演唱会、马拉松赛事、高考中考等&#xff09;期间&#xff0c;城市交通面临瞬时人流车流激增、传统摄像头模糊、交通拥堵识别滞后等问题。以演唱会为例&#xff0c;暖城商圈曾因观众集中离场导致周边…...

在rocky linux 9.5上在线安装 docker

前面是指南&#xff0c;后面是日志 sudo dnf config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo sudo dnf install docker-ce docker-ce-cli containerd.io -y docker version sudo systemctl start docker sudo systemctl status docker …...

条件运算符

C中的三目运算符&#xff08;也称条件运算符&#xff0c;英文&#xff1a;ternary operator&#xff09;是一种简洁的条件选择语句&#xff0c;语法如下&#xff1a; 条件表达式 ? 表达式1 : 表达式2• 如果“条件表达式”为true&#xff0c;则整个表达式的结果为“表达式1”…...

P3 QT项目----记事本(3.8)

3.8 记事本项目总结 项目源码 1.main.cpp #include "widget.h" #include <QApplication> int main(int argc, char *argv[]) {QApplication a(argc, argv);Widget w;w.show();return a.exec(); } 2.widget.cpp #include "widget.h" #include &q…...

Qt Http Server模块功能及架构

Qt Http Server 是 Qt 6.0 中引入的一个新模块&#xff0c;它提供了一个轻量级的 HTTP 服务器实现&#xff0c;主要用于构建基于 HTTP 的应用程序和服务。 功能介绍&#xff1a; 主要功能 HTTP服务器功能&#xff1a; 支持 HTTP/1.1 协议 简单的请求/响应处理模型 支持 GET…...

三体问题详解

从物理学角度&#xff0c;三体问题之所以不稳定&#xff0c;是因为三个天体在万有引力作用下相互作用&#xff0c;形成一个非线性耦合系统。我们可以从牛顿经典力学出发&#xff0c;列出具体的运动方程&#xff0c;并说明为何这个系统本质上是混沌的&#xff0c;无法得到一般解…...

laravel8+vue3.0+element-plus搭建方法

创建 laravel8 项目 composer create-project --prefer-dist laravel/laravel laravel8 8.* 安装 laravel/ui composer require laravel/ui 修改 package.json 文件 "devDependencies": {"vue/compiler-sfc": "^3.0.7","axios": …...

Java + Spring Boot + Mybatis 实现批量插入

在 Java 中使用 Spring Boot 和 MyBatis 实现批量插入可以通过以下步骤完成。这里提供两种常用方法&#xff1a;使用 MyBatis 的 <foreach> 标签和批处理模式&#xff08;ExecutorType.BATCH&#xff09;。 方法一&#xff1a;使用 XML 的 <foreach> 标签&#xff…...

【Redis】笔记|第8节|大厂高并发缓存架构实战与优化

缓存架构 代码结构 代码详情 功能点&#xff1a; 多级缓存&#xff0c;先查本地缓存&#xff0c;再查Redis&#xff0c;最后才查数据库热点数据重建逻辑使用分布式锁&#xff0c;二次查询更新缓存采用读写锁提升性能采用Redis的发布订阅机制通知所有实例更新本地缓存适用读多…...

【SpringBoot自动化部署】

SpringBoot自动化部署方法 使用Jenkins进行持续集成与部署 Jenkins是最常用的自动化部署工具之一&#xff0c;能够实现代码拉取、构建、测试和部署的全流程自动化。 配置Jenkins任务时&#xff0c;需要添加Git仓库地址和凭证&#xff0c;设置构建触发器&#xff08;如GitHub…...