数据结构--one

单链表

单链表简单实现

(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()函数功能的代码。*/

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值