1数据结构的分类,算法效率的度量

一,数据结构的定义和分类

数据结构:数据之间的关系即数据的逻辑结构,因为要存储到计算机里,所以视为将这个数据的逻辑结构映射到存储器里。即数据因为自身的和其他的数据的关系而在计算机内存储的方式。我们就归类了一些类型。

二,算法的定义和效率度量

算法:数据之间要运算,不同的数据结构也有更适合自己的算法,题目中也不会说告诉你要怎么存储使用数据,需要自己辨别,并在多个算法中根据算法效率的度量(两个),选择最优的算法。

算法效率的度量:

1.时间复杂度T(n)=O(f(n))

1>怎么算:

①只看语句重复最多次的那个语句称为基本语句,比如如果是多层嵌套则最深层的嵌套即基本语句

②多层嵌套可以借助数学公式求和

③找出执行次数k与n的关系,表示为k=g(n),即O(k)=O(g(n))为所求

④运用加法法则和乘法法则:可以分成几个可以估算的部分

⑤忽略低次幂项(即忽略不是最大执行频率的语句)和最高次幂系数(即常数不要)

2>时间复杂度的分类:选平均和最坏居多,默认最坏,以保证算法的运行时间不比它长

例:用顺序查找在n个元素数组中找key,最好:1次即1;最坏:n次即n;平均:O(n/2)=O(n)

3>算法时间效率的比较(用图像记)

O(log2n)可以直接写成O(logn),这种对数的其实下角标不重要

2.空间复杂度S(n)=O(f(n))

空间复杂度是算法所需存储空间的度量,由以下两个部分组成

算法本身需要占据的空间:变量,常数,指令,输入输出

算法要使用的辅助空间

例:这里t和b[i]都是辅助空间,相当于临时用的

相关推荐
tobias.b25 分钟前
408真题-2009-7-数据结构-无向连通图性质
数据结构·算法·408考研·408真题·真题解析
阿猿收手吧!1 小时前
【C++】JSON核心数据结构解析及JSONCPP使用
数据结构·c++·json
tobias.b1 小时前
408真题解析-2009-9-数据结构-小根堆-排序
数据结构·408考研·408真题·真题解析
D_FW2 小时前
数据结构第二章:线性表
数据结构·算法
tobias.b2 小时前
408真题解析-2009-8-数据结构-B树-定义及性质
数据结构·b树·计算机考研·408考研·408真题
hk11242 小时前
【Architecture/Refactoring】2026年度企业级遗留系统重构与高并发架构基准索引 (Grandmaster Edition)
数据结构·微服务·系统架构·数据集·devops
im_AMBER3 小时前
Leetcode 95 分割链表
数据结构·c++·笔记·学习·算法·leetcode·链表
无限进步_3 小时前
【C语言】堆(Heap)的数据结构与实现:从构建到应用
c语言·数据结构·c++·后端·其他·算法·visual studio
再难也得平3 小时前
两数之和和字母异位词分组
数据结构·算法
黎雁·泠崖3 小时前
【线性表系列入门篇】从顺序表到链表:解锁数据结构的进化密码
c语言·数据结构·链表