| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 数据结构与算法 -> 顺序表和链表的优缺点(图解) -> 正文阅读 |
|
[数据结构与算法]顺序表和链表的优缺点(图解) |
目录 顺序表:首先我们先来随意定义一个顺序表
我们这里就可以直观的看出顺序表的优点 顺序表的优点:在物理空间上是连续的,用下标可以很方便的访问(擅长二分法等) 但是缺点也是显而易见的 顺序表的第一个缺点:如果我的size==capacity,即我数放满了,需要扩容的话,那么我们就有两种方式扩容 (一)频繁的少量扩容,一次扩一个,一次扩一个,这样使得扩容的消耗变得非常巨大 (二)大量的扩容,比如翻倍从100个—>200个,那么假如我只存放101个数,就会浪费99个额外的空间,就会造成大量空间浪费 顺序表的第二个缺点:如果我需要修改数据(比如头插尾插) 以尾插举例,那么我需要遍历整个数组找到末尾的数字,然后在他后面插入。 如果这个数组有1亿个数字,那么计算机需要遍历1亿个数(有些夸张但是那个意思),才能插入,这种挪动数字的效率非常低下O(N); 链表:我们这里随意定义一个带头双向循环链表
?我们这里也可以直观的看出链表的优点 链表的第一个优点:链表是在内存中任意位置开辟的,能够按需申请和释放空间,不会造成空间浪费 链表的第二个优点:如果我现在需要修改数据(头插,尾插等) 这里拿尾插举例,我们只需要malloc一个新的结点,让结构体的最后一个指针(tail=phead->prev)指向新的结点 (直接就能找到最后一个结点,不用遍历数组),所以修改数据效率非常高O(1); ?链表的缺点:因为是在内存中随机开辟,所以像二分查找,排序等需要物理空间上连续的算法无法支持 ?总结:顺序表的优点: 1、物理空间是连续的,方便用下标访问。 2、CPU高速缓存命中率高(看后文补充知识,了解即可) 缺点: 1、由于物理空间连续,扩容时容易造成空间浪费和频繁扩容。 2、挪动数据的效率低下O(N); 链表的优点: 1、挪动数据的效率高O(1); 2。能按需申请释放空间,不会造成内存浪费。 缺点: 不支持下标随机访问,二分法或排序等算法不适合运行。 补充知识CPU高速缓存命中率:编译链接,生成可执行程序,cpu会执行这个程序,然后cup就会去访问内存。 但是对于处理数据,cup相对于内存处理的速度快很多。 打个比方,一个二十岁的青壮年和一个九十岁的老大爷一起合作搬砖,那么这个二十岁的青壮年大部分时间都在等待老大爷给他递砖头,那么这样处理的效率就会非常低下。 所以cpu会把数据存储到三级缓存或者寄存器,而不会直接访问内存。 一些4或者8byte的小数据就放到寄存器,而一些很大的数据就放到缓存里面。 那么具体cpu会怎么做呢,下面是顺序表和链表的情况 ?顺序表: 假如我们cpu是第一次遇到这个数字,图中顺序表的”1”(因为在实际过程中,有可能在运行其他程序的时候偶然间访问过这个数字,所以我们这里假设第一次遇到),那么cpu没有见过,我们就说这次cpu没有命中 那么cup就会接连访问”1”这个数的后面连续的几个空间(这个和电脑配置有关,每台可能不一样),然后访问的接下来几个数,就是cpu已经知道的数,所以cpu命中 ?链表: 那么同理,如果是链表,那么因为链表是在内存中随即开辟和生成的,假如我的1,2,3,4都在内存中隔得很远,我cup访问”1”的时候,连续访问1的后面几个空间,都没有访问到2,那么接下来访问2的时候cpu还是不认识2,所以cup会一直未命中 |
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 | -2025/1/8 5:24:37- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |