数据结构-时间、空间复杂度-详解

数据结构-时间复杂度-详解

  • 1.前言
    • 1.1数据结构与算法
    • 1.2如何衡量一个算法的好坏
    • 1.3复杂度
  • 2.时间复杂度
    • 2.1是什么
    • 2.2大O符号
      • 只保留最高阶项
      • 不带系数
      • 常数次为`O(1)`
    • 2.3示例
      • 示例2.1
      • 示例2.2
      • 示例2.3
      • 示例2.4
    • 2.4题目
  • 3.空间复杂度
    • 3.1是什么
    • 3.2大O符号
    • 3.3示例
      • 示例1
      • 示例2
      • 示例3
      • 示例4
  • 4.题目类型
      • IO型
      • 接口型

1.前言

1.1数据结构与算法

在计算机科学中,数据结构是一种数据组织、管理和存储的格式。
算法是指解题方案的准确而完整的描述,是一系列解决问题的清晰指令,算法代表着用系统的方法描述解决问题的策略机制。

通俗来讲,数据结构就是如何在内存中对数据进行管理。
算法就是指如何对内存中的数据进行处理。

1.2如何衡量一个算法的好坏

当小A写了一个快速排序,小B写了一个冒泡排序,二者想要比谁的算法更好。
同样的数据,小A在其低配版的电脑上处理,小B则在高配版的电脑上处理,最后小B的冒泡排序竟比小A的快速排序还快,这能说明快速排序比冒泡排序差吗?显然不能。
为了排除环境差异对算法运行结果的影响,引入了复杂度的概念。

1.3复杂度

复杂度是衡量算法效率的重要标准,分为时间复杂度空间复杂度,今天讲时间复杂度。

2.时间复杂度

2.1是什么

算法的时间复杂度是一个函数,描述了算法运行时间与输入数据规模之间的关系。
简单讲,时间复杂度就是一个算法运行时,大概的基本操作的执行次数


示例1.1:

int fun(int N)
{for(int i=0;i<N;i++){for(int j=0;j<N;j++){//语句一}}for(int i=0;i<2*N;i++){//语句二}for(int i=0;i<10;i++){//语句三}
}

其中语句一被执行N^2
语句二被执行2*N
语句三被执行10
fun()基本操作的执行次数:

N101001000
次数130102101002010

可以看到,随N增大,次数与最高阶的关系最大,因此在分析时间复杂度时,我们通常关注的是算法运行时间随着输入规模趋于无穷大时的趋势,这里我们使用大O符号

2.2大O符号

大O符号(Big O notation)是用于描述函数渐近行为的数学符号。更确切地说,它是用另一个(通常更简单的)函数来描述一个函数数量级的渐近上界。

推导方法:

只保留最高阶项

如在上面的示例1.1中,f(N)=N^2 + 2*N + 10 ,只保留最高阶项,则时间复杂度O(N^2)

不带系数

示例1.2:

int fun(int N)
{for(int i=0;i<2*N;i++){//语句二}for(int i=0;i<10;i++){//语句三}
}

时间复杂度O(N)
N趋近于无穷,系数的影响可以忽略不计,因此不带系数

常数次为O(1)

示例1.3:

int fun(int N)
{for(int i=0;i<10;i++){//语句三}
}

时间复杂度N(1)
这里的1不是指一次,而是常数次

2.3示例

示例2.1

const char * strchr ( const char * str, int character );

strchr为字符查找函数,作用是在字符串str中寻找目标字符character
查找次数:

最好平均最坏
1次N/2 次N次

当情况不唯一时,选最坏的情况,
时间复杂度O(N),这样可以保证任何情况都能满足预期

示例2.2

冒泡排序

最好最坏
N次N*N/2 次

在冒泡排序前,我们并不知道数组有序无序,因此最好需N
而最坏需N+(N-1)+(N-2)+...+2+1 == N*N/2
因此,时间复杂度O(N^2)

示例2.3

二分查找

最好最坏
1次log2N 次

时间复杂度O(logN)

:在时间复杂度中,由于log2N不好打,因此常用logN代替

对二分查找,只需几组数据就能体会其优越性:

N1000100万10亿
大概的执行次数10次20 次30次

如果将全中国人的信息排好序放入数组,给出一个身份证号码,最多只需31次即可找到那个人的信息。
但二分查找实用性却不强,因为使用其的前提是有序数组
因此,在生活中,用得更多的是红黑树,即一种自平衡二叉查找树

示例2.4

斐波拉契数列的递归写法:
在这里插入图片描述
时间复杂度O(2^N)

N10次20 次30次
大概的执行次数1000100万10亿

这与二分查找处于两个极端,即较少数据就需大量的计算,因此极不推荐使用

2.4题目

消失的数字

题目描述:数组nums包含从0到n的所有整数,但其中缺了一个。请编写代码找出那个缺失的整数。你有办法在O(n)时间内完成吗?

示例 1:

输入:[3,0,1]
输出:2

示例 2:

输入:[9,6,4,2,3,5,7,0,1]
输出:8

法一:
为了做这道题,我首先想到先排序在查找,即使用qsort,但很遗憾,qsort的时间复杂度为O(N*logN)
法二:
异或

int missingNumber(int* nums, int numsSize)
{int ret=0;for(int i=0;i<numsSize;i++){ret^=nums[i];}for(int i=0;i<=numsSize;i++){ret^=i;}return ret;
}

时间复杂度O(N)
思路:a^a=0a^0=a,因此,ret分别异或数组各元素,并分别异或0~N,得消失的数字
法三:
公式

int missingNumber(int* nums, int numsSize)
{int ret=0;int i=0;for(i=0;i<numsSize;i++){ret+=(nums[i]-i);}return i-ret;
}

时间复杂度O(N)

思路:计算0~N的总和,减去数组元素总和,得消失的数字

3.空间复杂度

3.1是什么

前面我讲到了时间复杂度,它是一个算法运行时,大概的基本操作的执行次数
与此相应,空间复杂度并非指算法运行时所占空间具体大小,如几个比特、几个字节,而指所额外创建的变量个数

3.2大O符号

这里的大O符号,与时间复杂度中的用法完全一致,遵循一下三点:

  • 仅保留最高阶项
  • 不带系数
  • 常数次为 O(1)

在这里插入图片描述

3.3示例

示例1

冒泡排序
在冒泡排序中,更多的是在循环、比较、交换,而未创建新的数组。
为了执行循环、交换,创建了常数个变量,因此,空间复杂度N(1)
这也意味着无论输入数组的大小如何,所需的额外空间都是固定的。

示例2

打印斐波拉契数列前N项
为了打印前N项,必须能够储存这些信息,可创建元素个数为N的数组。
数组的大小直接与输入 N 相关,空间复杂度O(N)

示例3

递归求阶乘
求阶乘的递归方法中,通过函数调用函数、N不断变小,最终返回N!
在此过程中,在函数中只进行了判断、调用、返回等操作,未创建额外的变量。
但,函数在调用时会创建其函数栈帧,每个函数栈帧占常数个空间。
因此,空间复杂度O(N)

示例4

斐波拉契数列递归求第N项
当使用了递归,就意味着会创建新的函数栈帧。
此处,递归写法中,每个函数栈帧未创建额外的变量,占常数个空间。
因此,空间复杂度取决于最多的同时创建的函数栈帧数量。
需明确,在遇到return Fib(n-1)+Fib(n-2),首先执行的是Fib(n-1)
N=5的情况,可得下图:
在这里插入图片描述
可见,最多的同时创建的函数栈帧数量为N-1
空间复杂度O(N)

4.题目类型

平常做题时,大多会遇到两种类型,这里略做介绍:

IO型

scanf拿输入条件,由printf打印输出结果,写的是完整程序。

接口型

输入条件为参数,由返回值返回结果,目的是实现一个函数,写的是部分程序。


本文示例中代码部分较少,很多只给了思路,而未给具体代码,
因为我认为,想求复杂度,最好的方法不是死盯代码,而是画、想。

希望本篇文章对你有所帮助!并激发你进一步探索数据结构和算法的兴趣!

本人仅是个C语言初学者,如果您有任何疑问或建议,欢迎随时留言讨论!让我们一起学习,共同进步!

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

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

相关文章

2024-08-26 更改驱动器号导致的软件崩溃问题

​ 在给电脑重新分盘时&#xff0c;想把 Software 盘的驱动器号&#xff08;E:&#xff09;改为对应的首字母 S&#xff0c;因此导致了所有软件崩溃。主要原因是软件主要依据驱动器号识别位置&#xff0c;而更改驱动器号后&#xff0c;并不会将软件设置的驱动器号一并更改。 ​…

Docker 的简介

Docker 的简介 为什么会有 Docker环境一致性问题提高资源利用率和可移植性快速部署和伸缩简化管理和维护版本控制和回滚 Docker 的历史dotCloud 时代&#xff08;2010年前&#xff09;Docker 诞生&#xff08;2010-2013&#xff09;快速发展与开源&#xff08;2013-2014&#x…

车载通信框架--- 以太网重连Port口相关思考

我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 屏蔽力是信息过载时代一个人的特殊竞争力,任何消耗你的人和事,多看一眼都是你的不对。非必要不费力证明自己,无利益不试图说服别人,是精神上的节…

手机mkv转换mp4:轻松实现视频格式兼容

如今手机已成为我们日常生活中不可或缺的伴侣&#xff0c;而视频文件则是我们享受娱乐、获取信息的重要来源。然而&#xff0c;由于不同设备和平台对视频格式的支持各有不同&#xff0c;我们有时会遇到无法在手机上播放某些视频文件的问题。 mkv是一种常见的视频格式&#xff…

java接口 controller层接收list集合传参,postman 调用接口时required parameter XXX is not present

开发过程中开发一个java接口 controller层接收list集合传参&#xff0c;然后postman调用一直不成功&#xff0c;报错 使用RequestParam方式&#xff0c;如果postman 调用接口时报错required parameter XXX is not present 可能是&#xff08;value“items”&#xff09;跟你输…

A Neural Probabilistic Language Model

摘要 统计语言建模的一个目标是学习单词序列的联合概率函数。由于维度的诅咒&#xff0c;这在本质上是困难的:我们建议用它自己的武器来对抗它。在提出的方法中&#xff0c;人们同时学习(1)每个单词的分布式表示&#xff08;词向量&#xff09;(即单词之间的相似性)以及(2)表示…

在进行网站链接时,‌加上http或https的重要性不言而喻

这一简单的操作背后&#xff0c;‌蕴含着对搜索引擎优化&#xff08;‌SEO&#xff09;‌的深刻理解&#xff0c;‌以及对网站权重提升的精准把握。‌以下&#xff0c;‌我们将深入探讨这一话题&#xff0c;‌以期为您的网站优化提供有价值的参考。‌优化&#xff08;‌SEO&…

C/C++控制台贪吃蛇游戏的实现

&#x1f680;欢迎互三&#x1f449;&#xff1a;程序猿方梓燚 &#x1f48e;&#x1f48e; &#x1f680;关注博主&#xff0c;后期持续更新系列文章 &#x1f680;如果有错误感谢请大家批评指出&#xff0c;及时修改 &#x1f680;感谢大家点赞&#x1f44d;收藏⭐评论✍ 一、…

数据可视化大屏模板-美化图表

Axure作为一款强大的原型设计软件&#xff0c;不仅擅长构建交互式界面&#xff0c;更在数据可视化方面展现出了非凡的创意与实用性。今天&#xff0c;就让我们一起探索Axure设计的几款精美数据可视化大屏模板&#xff0c;感受数据之美。 立体图表的视觉冲击力 Axure的数据可视…

银河麒麟桌面操作系统V10:如何设置应用开机自启动?

银河麒麟桌面操作系统V10&#xff1a;如何设置应用开机自启动&#xff1f; 1、图形界面设置2、命令行设置3、注意 &#x1f496;The Begin&#x1f496;点点关注&#xff0c;收藏不迷路&#x1f496; 1、图形界面设置 打开“设置”->“系统”->“开机启动”。点击“添加…

5000套精美PPT免费分享

目录 部分展示目录 几乎包含各种应用场景的PPT模板 这里只展示部分目录 部分展示目录 ##PPT下载 链接&#xff1a;https://pan.baidu.com/s/1ckvN9xeMR82hL30lHXfJ0g 提取码&#xff1a;ZYNB 点击下载&#xff0c;记得点个赞哦

ELK进阶-安全认证设置流程介绍

目录 一、前言 二、ElasticSearch的安全认证配置 设置ElasticSearch的安全认证功能&#xff08;最低&#xff09; 启用TLS/SSL加密通信 &#xff08;1&#xff09;生成CA证书 &#xff08;2&#xff09;生成transport证书 &#xff08;3&#xff09;生成http证书 &#…

docker镜像,ip,端口映射,持久化

docker 镜像的迁移&#xff1a;导出和导入镜像 查看镜像&#xff1a; [rootdocker ~]# docker images REPOSITORY TAG IMAGE ID CREATED SIZE centos latest 5d0da3dc9764 2 years ago 231MB 打包 将镜像打包&#xff0c;找到save,可以将…

【非常困难】 猿人学web第一届 第10题 js 混淆 - 重放攻击对抗

文章目录 调试干扰第一个 debuggerHook 代码 第二个 debuggerHook 代码 第三个 Function.constructor.prototype 检测Hook 代码 完整的 Hook 代码 接口分析加密参数 m 生成位置加密参数还原加密点扣代码提示_yrxyA\$()var _yrxmEu _yrxWKg(_yrxyHJ...._yrxWKg() let result _…

半枚玄月照见人间空荡荡

半枚玄月照见人间空荡荡 昨夜玄月昨夜风&#xff0c;轻吹往事落心中。 众里寻他为何事&#xff1f;鸡鸣月落一场空。玄月 沙发上刷短视频笑得不经意抬头&#xff0c;忽而瞥见窗口防盗网挂着半枚月亮&#xff0c;玄黄色的&#xff0c;温润而冷冽&#xff0c;引人注目。 手机里…

国货之光|暴雨机推出面向大模型训练的AI服务器

当前&#xff0c;“百模大战”带来了算力需求的爆发&#xff0c;尤其是以ChatGPT为代表的多模态AI大模型&#xff0c;‌其参数规模和训练数据量均达到了前所未有的规模。‌GPT-3.5、‌GPT-4等模型的参数规模突破了万亿级别&#xff0c;‌训练数据量达到了TB级别&#xff0c;‌这…

zdppy+vue3+onlyoffice文档管理系统实战 20240823上课笔记 zdppy_cache框架的低代码实现

遗留问题 1、封装API2、有账号密码3、查询所有有效的具体数据&#xff0c;也就是缓存的所有字段 封装查询所有有效具体数据的方法 基本封装 def get_all(self, is_activeTrue, limit100000):"""遍历数据库中所有的key&#xff0c;默认查询所有没过期的:para…

51单片机——LED灯控制

1、LED介绍 中文名&#xff1a;发光二极管 外文名&#xff1a;Light Emitting Diode 简称&#xff1a;LED 用途&#xff1a;照明、广告灯、指引灯、屏幕 2、LED原理图 电阻在原理图上标注为1k&#xff0c;表示这是1千欧的电阻&#xff0c;实际在电路板上的表示是102 102解…

Godot《躲避小兵》实战之创建游戏主场景

游戏主场景 现在是时候将我们所做的一切整合到一个可玩的游戏场景中了。 创建新场景并添加一个 Node节点&#xff0c;命名为 Main。&#xff08;我们之所以使用 Node 而不是 Node2D&#xff0c;是因为这个节点会作为处理游戏逻辑的容器使用。本身是不需要 2D 功能的。&#x…

C\C++ Sqlite3使用详解

C\C++ Sqlite3使用详解 一、源码下载二、sqlite3接口说明C++2.1 项目创建以及sqlite3使用2.1 连接数据库2.2 sqlite创建表2.2.1 示例代码2.2.2 注意事项2.3 sqlite插入数据2.3.1 示例代码2.3.2 注意事项2.4 sqlite数据删除2.5 sqlite数据查询一、源码下载 下载地址: https://…