数据结构的入门了解,时间复杂度和空间复杂度你真的知道吗《数据结构与算法》

简介: 数据结构的入门了解,时间复杂度和空间复杂度你真的知道吗《数据结构与算法》

序言

温馨提醒,想直接看正文的可以跳过本段哈。在上个月底作者终于结束了C语言的入门和深剖,对的,之前说过进阶还在路上哈(寒假就有了哈)。然后一直到现在才再次冒头,绝对不是玩去了哈,我没有偷懒哈,咳咳,当然也确实休息了两天,跨年嘛不是(这绝对不是我去浪的借口咳咳),不过紧接着就是莽数据结构去了,在此之前是接触了一点的,那时学完了顺序表,链表,栈和队列,然后消失的这几天就再次复习了一下,真的是解决了当时很多的疑惑,收获真的很多,当然也不是复习这一个原因,因为复习之前也把C语言理论是学完了,这也是理解更深一个很重要的原因哈。然后就一直往下学,至1月3日晚,作者完成了这2022的第一篇博客,其实开始是没准备来写的,本想着把数据结构快速过一遍再来写博客的,但是可能一直看视频而且用倍数吧,脑袋有点晕乎乎的,在队列结束后就是二叉树了,然后二叉树又是比前面的更难一些,所以就准备第二天再去肝他,状态会好点,然后就有了本篇文章。想了想,数据结构对于小白不像之前那么容易理解,而且作者也想去更加完善文章,提升一下文章的品质,而且准备一下写一个大内容,比如链表就是一个单内容这样,不要像之前的分篇去写,当然之前是没办法哈,内容太多了,一起太杂了,而且关联性也不是那么强,但是数据结构关联性很强而且内容不是太多可能更多偏于理解(就目前觉得),所以就准备一大块一大块内容来写哈,感觉应该挺不错的。但是之后的更新速度应该会慢一点了,可能两三篇一周吧?但是绝对精哈!当然也可能有一些其他的文章,但是数据结构更新应该是快也快不了太多吧。好像想说的也就这么多,让我们一起加油吧!冲刺大厂,不负未来,不负你!  


谁都不能阻挡你成为更优秀的人。  

1. 数据结构前言


1.1. 什么是数据结构?


数据结构(Data Structure)是计算机存储、组织数据的方式,指相互之间存在一种或多种特定关系的数据元素的集合。


1.2.什么是算法?

算法(Algorithm):就是定义良好的计算过程,他取一个或一组的值为输入,并产生出一个或一组值作为输出。简单来说算法就是一系列的计算步骤,用来将输入数据转化成输出结果。

 

1.3.如何学好数据结构和算法


3.1. 死磕代码,磕成这样就可以了(=。=哈哈)


image.png


3.2. 注意画图和思考


两点都非常重要,如果要做一个好的程序员,数据结构的学习绝对是必不可少的哈!


2. 什么是时间复杂度和空间复杂度?


大家一般都是在各种算法题目上面看见的,是一个限制条件,其实网上是有很多篇幅去讲这个东西,但是其实很简单。总结就是时间复杂度不看时间,看次数。空间复杂度不看空间看个数


2.1. 算法效率

算法效率分析分为两种:第一种是时间效率,第二种是空间效率。 间效率被称为时间复杂度,而空间效率被称作空间复杂度。 时间复杂度主要衡量的是一个算法的运行速度,而空间复杂度主要衡量一个算法所需要的额外空间,在计算机发展的早期,计算机的存储容量很小。所以对空间复杂度很是在乎。但是经过计算机行业的迅速发展,计算机的存储容量已经达到了很高的程度。所以我们如今已经不需要再特别关注一个算法的空间复杂度


2.2. 时间复杂度的概念

时间复杂度的定义:在计算机科学中,算法的时间复杂度是一个函数,它定量描述了该算法的运行时间。一个算法执行所耗费的时间,从理论上说,是不能算出来的,只有你把你的程序放在机器上跑起来,才能知道。但是我们需要每个算法都上机测试吗?是可以都上机测试,但是这很麻烦,所以才有了时间复杂度这个分析方式。一个算法所花费的时间与其中语句的执行次数成正比例,算法中的基本操作的执行次数,为算法的时间复杂度。

即:找到某条基本语句与问题规模N之间的数学表达式,就是算出了该算法的时间复杂度。


2.3. 空间复杂度的概念

空间复杂度是对一个算法在运行过程中临时占用存储空间大小的量度。

空间复杂度不是程序占用多少byte空间,因为这个也没太大意义,所以空间复杂度算的是变量的个数。空间复杂度计规则基本跟时间复杂度类似,也使用大O渐进表示法。

注意:函数运行时所需要的栈空间(存储参数、局部变量、一些寄存器信息等)在编译期间已经确定好了,因此空间复杂度主要通过函数在运行时候显示申请的额外空间来确定。


3. 如何计算常见算法的时间复杂度?


3.1. 让我们来举个栗子(重点)


image.png


实际中我们计算时间复杂度时,我们其实并不一定要计算精确的执行次数,而只需要大概执行次数,那么这里我们使用大O的渐进表示法。

大O符号(Big O notation):是用于描述函数渐进行为的数学符号。


这上面的时间复杂度就是N*N+2*N+10,但是如果N够大,2*N和10就显得很小,可以忽略不计,此时N*N非常大,所以时间复杂度就是O(N^2)。


再说明,比如我们去N个数里面找一个数(没有相同的),有三种情况,最好情况一次找到,平均情况N/2,最坏情况N次找到在实际中一般情况关注的是算法的最坏运行情况,所以数组中搜索数据时间复杂度为O(N) 。  


1. 基本操作执行了2N+10次,通过推导大O阶方法知道,时间复杂度为 O(N)。


2. 基本操作执行了M+N次,有两个未知数M和N,时间复杂度为 O(N+M)。(要注意N,M差距大不大)


3. 基本操作执行了10次,通过推导大O阶方法,时间复杂度为 O(1)。(只要是只有准确的数字就是O(1))


4. 基本操作执行最好1次,最坏N次,时间复杂度一般看最坏,时间复杂度为 O(N)。

5. 基本操作执行最好N次,最坏执行了(N*(N+1)/2次,通过推导大O阶方法+时间复杂度一般看最坏,时间复杂度为 O(N^2)。

6. 基本操作执行最好1次,最坏O(logN)次,时间复杂度为 O(logN) 。ps:logN在算法分析

中表示是底数为2,对数为N。有些地方会写成lgN(其实是错的,与数学有矛盾)。

7. 基本操作递归了N次,时间复杂度为O(N)。


3.2. 时间复杂度对比(图解)


image.png


image.png


4. 如何计算常见算法的空间复杂度?


image.png


使用了常数个额外空间,所以空间复杂度为 O(1)。(上面不一定画完了哈,就是有多少个变量,但是是常数个,和时间复杂度是差不多的其实,就是看的东西不一样)。


image.png


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


今天的内容就到这里了哈!!!

要是认为作者有一点帮助你的话!

就来一个点赞加关注吧!!!当然订阅是更是求之不得!

最后的最后谢谢大家的观看!!!

你们的支持是作者写作的最大动力!!!

下期见哈!!!

相关文章
|
4月前
|
机器学习/深度学习 算法 数据挖掘
K-means聚类算法是机器学习中常用的一种聚类方法,通过将数据集划分为K个簇来简化数据结构
K-means聚类算法是机器学习中常用的一种聚类方法,通过将数据集划分为K个簇来简化数据结构。本文介绍了K-means算法的基本原理,包括初始化、数据点分配与簇中心更新等步骤,以及如何在Python中实现该算法,最后讨论了其优缺点及应用场景。
226 6
|
4月前
|
算法 数据处理 C语言
C语言中的位运算技巧,涵盖基本概念、应用场景、实用技巧及示例代码,并讨论了位运算的性能优势及其与其他数据结构和算法的结合
本文深入解析了C语言中的位运算技巧,涵盖基本概念、应用场景、实用技巧及示例代码,并讨论了位运算的性能优势及其与其他数据结构和算法的结合,旨在帮助读者掌握这一高效的数据处理方法。
124 1
|
7天前
|
存储 算法 Java
算法系列之数据结构-二叉树
树是一种重要的非线性数据结构,广泛应用于各种算法和应用中。本文介绍了树的基本概念、常见类型(如二叉树、满二叉树、完全二叉树、平衡二叉树、B树等)及其在Java中的实现。通过递归方法实现了二叉树的前序、中序、后序和层次遍历,并展示了具体的代码示例和运行结果。掌握树结构有助于提高编程能力,优化算法设计。
41 9
 算法系列之数据结构-二叉树
|
5天前
|
算法 Java
算法系列之数据结构-Huffman树
Huffman树(哈夫曼树)又称最优二叉树,是一种带权路径长度最短的二叉树,常用于信息传输、数据压缩等方面。它的构造基于字符出现的频率,通过将频率较低的字符组合在一起,最终形成一棵树。在Huffman树中,每个叶节点代表一个字符,而每个字符的编码则是从根节点到叶节点的路径所对应的二进制序列。
28 3
 算法系列之数据结构-Huffman树
|
7天前
|
算法 Java
算法系列之数据结构-二叉搜索树
二叉查找树(Binary Search Tree,简称BST)是一种常用的数据结构,它能够高效地进行查找、插入和删除操作。二叉查找树的特点是,对于树中的每个节点,其左子树中的所有节点都小于该节点,而右子树中的所有节点都大于该节点。
48 22
|
1月前
|
存储 机器学习/深度学习 算法
C 408—《数据结构》算法题基础篇—链表(下)
408考研——《数据结构》算法题基础篇之链表(下)。
92 29
|
1月前
|
存储 算法 C语言
C 408—《数据结构》算法题基础篇—链表(上)
408考研——《数据结构》算法题基础篇之链表(上)。
106 25
|
1月前
|
存储 人工智能 算法
C 408—《数据结构》算法题基础篇—数组(通俗易懂)
408考研——《数据结构》算法题基础篇之数组。(408算法题的入门)
75 23
|
3月前
|
存储 运维 监控
探索局域网电脑监控软件:Python算法与数据结构的巧妙结合
在数字化时代,局域网电脑监控软件成为企业管理和IT运维的重要工具,确保数据安全和网络稳定。本文探讨其背后的关键技术——Python中的算法与数据结构,如字典用于高效存储设备信息,以及数据收集、异常检测和聚合算法提升监控效率。通过Python代码示例,展示了如何实现基本监控功能,帮助读者理解其工作原理并激发技术兴趣。
86 20
|
2月前
|
存储 算法 测试技术
【C++数据结构——树】二叉树的遍历算法(头歌教学实验平台习题) 【合集】
本任务旨在实现二叉树的遍历,包括先序、中序、后序和层次遍历。首先介绍了二叉树的基本概念与结构定义,并通过C++代码示例展示了如何定义二叉树节点及构建二叉树。接着详细讲解了四种遍历方法的递归实现逻辑,以及层次遍历中队列的应用。最后提供了测试用例和预期输出,确保代码正确性。通过这些内容,帮助读者理解并掌握二叉树遍历的核心思想与实现技巧。
60 2