时间复杂度与空间复杂度的详解

目录

1.时间复杂度

2.时间复杂度计算例题

3.空间复杂度


1.时间复杂度

算法中的基本操作的执行次数,为算法的时间复杂度。
如何表达 时间复杂度?
大O的渐进表示法
实际中我们计算时间复杂度时,我们其实并不一定要计算精确的执行次数,而只需要 大概执行次数,那么这里我们 使用大 O 的渐进表示法。
1、用常数1取代运行时间中的所有加法常数。
2、在修改后的运行次数函数中,只保留最高阶项。
3、如果最高阶项存在且不是1,则去除与这个项目相乘的常数。得到的结果就是大O

举例:

// 请计算一下 func1 基本操作执行了多少次?
void func1 ( int N ){
int count = 0 ;
for ( int i = 0 ; i < N ; i ++ ) {
for ( int j = 0 ; j < N ; j ++ ) {
count ++ ;
}
}
for ( int k = 0 ; k < 2 * N ; k ++ ) {
count ++ ;
}
int M = 10 ;
while (( M -- ) > 0 ) {
count ++ ;
}
System . out . println ( count );
}

 题解:

Func1 执行的基本操作次数 :
F(N)=N^2+2*N+10;
(1) 用常数1取代运行时间中的所有加法常数。
F(N)=N^2+2*N+1;
(2) 在修改后的运行次数函数中,只保留最高阶项。
F(N)=N^2;
=>O(N^2);

通过上面我们会发现大O的渐进表示法去掉了那些对结果影响不大的项,简洁明了的表示出了执行次数。  

另外有些算法的时间复杂度存在最好、平均和最坏情况:
最坏情况:任意输入规模的最大运行次数 ( 上界 )
平均情况:任意输入规模的期望运行次数
最好情况:任意输入规模的最小运行次数 ( 下界 )
一般情况下时间复杂度是算法的最坏运行情况
O(N)中N表示问题的规模

2.时间复杂度计算例题

例题1:

// 计算 func2 的时间复杂度?
void func2 ( int N , int M ) {
int count = 0 ;
for ( int k = 0 ; k < M ; k ++ ) {
count ++ ;
}
for ( int k = 0 ; k < N ; k ++ ) {
count ++ ;
}
System . out . println ( count );
}

答案及分析:

基本操作执行了M+N次,有两个未知数MN,时间复杂度为 O(N+M) 

例题2:

// 计算 func3 的时间复杂度?
void func3 int N ) {
int count = 0 ;
for ( int k = 0 ; k < 100 ; k ++ ) {
count ++ ;
}
System . out . println ( count );
}

 答案及分析:

基本操作执行了100次,通过推导大O阶方法,时间复杂度为 O(1)

 例题3:

// 计算 bubbleSort 的时间复杂度?
void bubbleSort ( int [] array ) {
for ( int end = array . length ; end > 0 ; end -- ) {
boolean sorted = true ;
for ( int i = 1 ; i < end ; i ++ ) {
if ( array [ i - 1 ] > array [ i ]) {
Swap ( array , i - 1 , i );
sorted = false ;
}
}
if ( sorted == true ) {
break ;
}
}
}

 答案及分析:

F(N)=(N-1+N-2+N-3……)==((N-1+1)*N)/2==0.5*N^2;

通过推导大 O 阶方法 + 时间复杂度一般看最坏,时间 复杂度为 O(N^2)

 例题4:

// 计算 binarySearch 的时间复杂度?
int binarySearch ( int [] array , int value ) {
int begin = 0 ;
int end = array . length - 1 ;
while ( begin <= end ) {
int mid = begin + (( end - begin ) / 2 );
if ( array [ mid ] < value )
begin = mid + 1 ;
else if ( array [ mid ] > value )
end = mid - 1 ;
else
return mid ;
}
return - 1 ;
}

 答案及分析:

方法1:

对于不能直接看出的并较复杂的问题,可以采用数学归纳法

 答案:

 方法2:

N/(2^x) =1(x为循环的执行次数)

x的解:

例题 5

// 计算阶乘递归 factorial 的时间复杂度?
long factorial ( int N ) {
return N < 2 ? N : factorial ( N - 1 ) * N ;
}

对于不能直接看出的并较复杂的问题,可以采用数学归纳法,但对于递归我们有专门总结的方法。

F(N)=递归的次数*每次递归代码的执行次数

 答案及分析:

通过计算分析发现基本操作递归了 N次, 每次递归代码的执行次数为1 时间复杂度为O(N)

例题6:

// 计算斐波那契递归 fifibonacci 的时间复杂度?
int fifibonacci ( int N ) {
return N < 2 ? N : fifibonacci ( N - 1 ) + fifibonacci ( N - 2 );
}

  答案及分析:

对于不能直接看出的并较复杂的问题,可以采用数学归纳法(不展开)

面对这种多递归入口的题,可以使用补全法。

何为补全法?

以F4为例

F(N): 

 

1+2+4+……+2^(N-1)
=2^N-1;
O(2^N)

3.空间复杂度

空间复杂度是对一个算法在运行过程中 临时占用存储空间大小的量度 。空间复杂度不是程序占用了多少 bytes 的空 间,因为这个也没太大意义,所以空间复杂度算的是变量的个数
空间复杂度计算规则基本跟时间复杂度类似 ,也 使用 O 渐进表示法
无论什么类型,只看开了多少的空间

 例题1:

// 计算 bubbleSort 的空间复杂度?
void bubbleSort ( int [] array ) {
for ( int end = array . length ; end > 0 ; end -- ) {
boolean sorted = true ;
for ( int i = 1 ; i < end ; i ++ ) {
if ( array [ i - 1 ] > array [ i ]) {
Swap ( array , i - 1 , i );
sorted = false ;
}
}
if ( sorted == true ) {
break ;
}
}
}

   答案及分析:

 使用了常数个额外空间,所以空间复杂度为 O(1)

例题2:

// 计算 fifibonacci 的空间复杂度?
int [] fifibonacci ( int n ) {
long [] fifibArray = new long [ n + 1 ];
fifibArray [ 0 ] = 0 ;
fifibArray [ 1 ] = 1 ;
for ( int i = 2 ; i <= n ; i ++ ) {
fifibArray [ i ] = fifibArray [ i - 1 ] + fifibArray [ i - 2 ];
}
return fifibArray ;
}

 答案及分析:

动态开辟了N个空间,空间复杂度为 O(N)

例题3:

// 计算阶乘递归 Factorial 的空间复杂度?
long factorial ( int N ) {
return N < 2 ? N : factorial ( N - 1 ) * N ;
}

  答案及分析:

递归调用了 N 次,开辟了 N 个栈帧,每个栈帧使用了常数个空间。空间复杂度为 O(N)

以上为我个人的小分享,如有问题,欢迎讨论!!! 

都看到这了,不如关注一下,给个免费的赞 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/35035.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ArcGIS Pro暨基础入门、制图、空间分析、影像分析、三维建模、空间统计分析与建模、python融合、案例应用

GIS是利用电子计算机及其外部设备&#xff0c;采集、存储、分析和描述整个或部分地球表面与空间信息系统。简单地讲&#xff0c;它是在一定的地域内&#xff0c;将地理空间信息和 一些与该地域地理信息相关的属性信息结合起来&#xff0c;达到对地理和属性信息的综合管理。GIS的…

【数据结构】树和二叉树

一、树的概念及结构 1、树的概念 树 是一种非线性的数据结构&#xff0c;它是由n&#xff08;n>0&#xff09;个有限结点组成一个具有层次关系的集合。把它叫做树是因 为它看起来像一棵倒挂的树&#xff0c;也就是说它是根朝上&#xff0c;而叶朝下的。 有一个特殊的结点&a…

php从静态资源到动态内容

1、从HTML到PHP demo.php:后缀由html直接改为php,实际上当前页面已经变成了动态的php应用程序脚本 demo.php: 允许通过<?php ... ?>标签,添加php代码到当前脚本中 php标签内部代码由php.exe解释, php标签之外的代码原样输出,仍由web服务器解析 <!DOCTYPE html>…

MySQL数据库基础语法

一&#xff0c;数据库操作 数据库中不区分大小写&#xff01;&#xff01;&#xff01; 1.1 显示数据库 show databases ; 如图&#xff1a; 1.2 创建数据库 create database [ if not exists ]数据库名 ; 如图&#xff1a; 1.3 使用数据库 use 数据库名 &#xff1b; 如图&a…

使用fopen等标准C库来操作文件

fopen 需要的头文件&#xff1a; #include <stdio.h> 函数原型&#xff1a; FILE *fopen(const char *pathname, const char *mode); 参数&#xff1a; pathname: 文件路径mode: “r” &#xff1a;以只读方式打开文件&#xff0c;该文件必须存在。“w” &#xff…

腾讯出了一个新聊天软件M8

众所周知&#xff0c;如今国内互联网&#xff0c;微信和QQ无疑是社交领域的霸主。 下载:https://www.123pan.com/s/BP5A-RW4xh.html 不过&#xff0c;它们也有各自局限性&#xff0c;比如难以结识新朋友、功能过于复杂等。 这让用户产生厌倦&#xff0c;再加上近几年AI、元宇…

使用requests如何实现自动登录

不知道大家有没有注意到&#xff0c;好多网站我们登录过后&#xff0c;在之后的某段时间内访问该网页时&#xff0c;不会给出请登录的提示&#xff0c;时间到期后就会提示请登录&#xff01;这样在使用爬虫访问网页时还要登录&#xff0c;打乱我们的节奏&#xff0c;那么如何使…

考研408 | 【计算机网络】 数据链路层

导图&#xff1a; 数据链路层概念&#xff1a; 结点&#xff1a;主机、路由器 链路&#xff1a;网络中两个结点之间的物理通道&#xff0c;链路的传输介质主要有双绞线、光纤和微波。分为有线链路、无线链路。 数据链路&#xff1a;网络中两个结点之间的逻辑通道&#xff0…

河道水位自动监测预警 yolov5

河道水位自动监测预警系统基于yolov5网络模型AI视频智能水尺读数技术&#xff0c;河道水位自动监测预警系统通过在河道周边布设监控摄像头&#xff0c;实时监测水位的变化&#xff0c;一旦水位超过预设阈值&#xff0c;将自动发出预警信号&#xff0c;并提示相关人员采取相应的…

Three.js 实现材质边缘通道发光效果

相关API的使用&#xff1a; 1. EffectComposer&#xff08;渲染后处理的通用框架&#xff0c;用于将多个渲染通道&#xff08;pass&#xff09;组合在一起创建特定的视觉效果&#xff09; 2. RenderPass(是用于渲染场景的通道。它将场景和相机作为输入&#xff0c;使用Three.…

使用script标签解决跨域问题,但是只能使用get请求,且不需要获取get请求的数据,例如埋点,只需要触发后发送get请求,而不需要获取返回的参数

在项目中&#xff0c;使用埋点的时候&#xff0c;因为使用的是外部提供的接口&#xff0c;所以直接请求的时候&#xff0c;前端会报跨域的问题&#xff0c;本着不麻烦后端的想法&#xff0c;怎怎么前端实现跨域而完全不需要后段的配合&#xff0c;这时候就想到了通过script标签…

【简单认识zookeeper+kafka分布式消息队列集群的部署】

文章目录 一、zookeeper1、定义2、工作机制3、Zookeeper 特点4、Zookeeper 数据结构5、Zookeeper 应用场景6、Zookeeper 选举机制&#xff08;1&#xff09;第一次启动选举机制&#xff08;2&#xff09;非第一次启动选举机制 7、部署zookeeper群集 二、消息队列概述1、为什么需…

百度云盘发展历程与影响

摘要&#xff1a; 百度云盘作为中国领先的云存储与共享服务提供商&#xff0c;自其创立至今经历了多个阶段的发展与变革。本论文通过对百度云盘的历史回顾与分析&#xff0c;探讨了其在技术、商业模式、用户体验以及对社会的影响等方面的演变。同时&#xff0c;还分析了在竞争激…

Mac下⬇️Git如何下载/上传远程仓库

使用终端检查电脑是否安装Git git --version 通过此文章安装Git ➡️ ​​​​​​​传送门&#x1f310; 方式1⃣️使用终端操作 1.下载——克隆远程仓库到本地 git clone [远程地址] 例&#xff1a;git clone https://gitee.com/lcannal/movie.git​ 2.编…

Windows - UWP - 为UWP应用创建桌面快捷方式

Windows - UWP - 为UWP应用创建桌面快捷方式 前言 这是一个较为简单的方式&#xff0c;不需要过多的命令行。 How 首先Win R -> shell:AppsFolder -> 回车&#xff0c; 这将显示电脑上的已安装应用&#xff08;Win32 & UWP&#xff09;&#xff1a; 找到想要创建…

【Nginx】Nginx负载均衡

负载均衡&#xff1a;通过反向代理来实现 Nginx的七层代理和四层代理&#xff1a; 七层是最常用的反向代理方式&#xff0c;只能配置在nginx配置文件的http模块当中 &#xff1b;配置的方法名称为&#xff1a;upstream模块&#xff0c;不能写在server中也不能写在location中&a…

ZABBIX 6.4的完全安装步骤

此安装文档是我一步一步的验证过的&#xff0c;按步骤来可以顺畅的安成ZABBIX6.4的部署。 Zabbix 主要有以下几个组件组成&#xff1a; Zabbix Server6.4&#xff1a;Zabbix 服务端&#xff0c;是 Zabbix 的核心组件。它负责接收监控数据并触发告警&#xff0c;还负责将监控数…

(2023Arxiv)Meta-Transformer: A Unified Framework for Multimodal Learning

论文链接&#xff1a;https://arxiv.org/abs/2307.10802 代码链接&#xff1a;https://github.com/invictus717/MetaTransformer 项目主页&#xff1a;https://kxgong.github.io/meta_transformer/ 【注】&#xff1a;根据实验结果来看&#xff0c;每次输入一种数据源进行处…

Ajax-AJAX请求的不同发送方式

&#x1f954;&#xff1a;你一定能成为想要成为的人 发送AJAX请求不同方式 发送AJAX请求不同方式1、jQuery发送AJAX请求2、axios发送AJAX请求&#xff08;重点&#xff09;3、fetch发送AJAX请求 发送AJAX请求不同方式 1、jQuery发送AJAX请求 首先需要jquery的js文件&#xf…

Vc - Qt - QToolButton

QToolButton 是 Qt 框架中的一个类&#xff0c;是 QPushButton 的子类。它可以显示一个可单击的按钮&#xff0c;并且可以与弹出菜单、图标和文本等进行关联。 QToolButton的一些常见特性和用法包括&#xff1a; 设置文本&#xff1a;使用 setText() 函数设置按钮上的文本。设置…