数据结构--one

xiaoxiao2021-02-28  119

单链表

单链表简单实现

(1)链表和数组的区别

数组静态分配内存,链表动态分配内存   数组必须事先定义固定大小,不能适应数据动态增减的情况。当数据增多时,可能超出原先定义的个数,当数据减少时,造成内存浪费。数组中插入、删除都需要移动其他元素。   而链表采用动态分配内存的形式实现,可以适应数据动态地增减的情况, 需要时可以用new/malloc分配内存空间,不需要时用delete/free将已分配的空间释放, 不会造成内存空间浪费,且可以方便地插入、删除数据项。 数组在内存中连续,链表不连续   数组的数据在内存中是连续存放的,而链表是随机。   数组的随机访问效率很高,但插入、删除就相对较。   链表的插入、删除相对数组有很高的效率,而如果要访问链表中的某个元素时,都得从头节点开始遍历链表,所以链表的随机访问效率相对较。 数组利用下标定位,时间复杂度为O(1),链表定位元素时间复杂度O(n)数组的插入删除时间复杂度为O(n),链表为O(1)

总结:   链表不存在越界问题,数组有越界问题。数组便于查找,链表便于插入、删除。数组节省空间,但是长度固定,链表可动态增加,但占用更多的存储空间。   如果需要快速访问数据,并且很少或不插入删除,应该用数组。 相反,如果插入删除操作较多就应该使用链表。 相关面试题: 单链表热点面试题一 单链表热点面试题二 链表带环相关问题

堆栈

(1)请讲述heao与stack的差别

申请方式   栈:由系统自动分配和释放。   堆:需要程序员自己申请,并指明大小,在C中用malloc函数,C++中用new申请后的响应   栈:只要栈的剩余空间大于所申请空间,系统将为程序提供内存,否则将报异常提示栈溢出。   堆:首先应该知道操作系统由一个记录空闲内存地址的链表,当系统受到程序的申请时,会遍历链表,寻找第一个空间大于所申请空间的堆节点,然后将该节点从空闲节点链表中删除,并将该节点的空间分配给程序。由于找到的堆节点的大小不一定正好等于申请的大小,系统会自动地将多余的部分重新放入空闲链表中。申请的大小限制   栈:栈是从高地址向低地址扩展的结构,是一块连续的内存的区域。也就是说栈顶的地址和栈的最大容量是系统预先规定好的。   堆:堆是想高地址扩展的数据结构,是不连续的内存区域。这是由于系统是用链表存储空闲内存地址的,自然是不连续的。而链表的遍历方式是从低地址到高地址,堆的大小受限与计算机系统中有效的虚拟内存。因此,堆获得的空间比较灵活,也比较大。申请效率的比较   栈:由系统自动分配,速度较快。但程序员无法控制。   堆:是由new分配的内存,一般速度比较慢,而且容易产生内存碎片,不过用起来方便。

数据结构堆简单实现

http://blog.csdn.net/qq_34312386/article/details/61416759  

/*编写实现链表排序的一种算法。说明为什么你会选择用这样的方法? 2.编写实现数组排序的一种算法。说明为什么你会选择用这样的方法? 3.请编写能直接实现strstr()函数功能的代码。*/

转载请注明原文地址: https://www.6miu.com/read-48547.html

最新回复(0)