链你妹系列1—关于链表,不得不吐槽的那些事

链你妹系列1—关于链表,不得不吐槽的那些事

 

1. 面试中的那些槽点

         本人是一名c/c++软件开发爱好者,因为烟酒僧期间倒腾项目偏向于软件开发,激发了不少兴趣,所以只在大学过了计算机二级c的我毅然投身软件开发行业,决定为浩瀚的IT行业添砖加瓦(添些bug)。

        哪知道漫漫IT路、处处是深坑,不说别的,光是毕业求职的那一阵,就趟了好多浑水好多坑。这里面最坑爹的,莫过于哪哪都要面链表的问题:

        去联想,最后几题是链表;

        去华为,现场一对一出题考链表;

        去小米,三道大题两道链表;



        ... ...

        哪儿面试都要考查链表;

       链表虐我千百遍,我待链表如初(ni)恋(mei)!

2. 为什么绕不开链表呢?

      为什么大家这么喜欢考察链表呢?那就该从链表这种数据结构的特点开始说起。

      链表是一种物理存储单元上非连续、非顺序逻辑上由链表中的指针顺序链接的存储结构。


      链表的几个优点:

       (1.)不需要预先知道数据的大小;

      (2.)充分利用计算机内存空间,实现灵活的动态内存管理

      这里需要说一下,例如我们存储班级成员信息,如果我们使用数组这种数据结构进行存储,那么遇到一个问题:数组定义多大?我们会在初始化的时候就申请固定的足够大的内存,即静态内存分配,但遇到人员有调整时,我们就需要去修改程序,另外成员数量波动也可能带来内存浪费或数组越界以致内存溢出的风险。

      那么怎么解决这个问题呢?就是使用动态内存分配
      所谓动态内存分配就是指在程序执行的过程中动态地分配或者回收存储空间的分配内存的方法。这就是链表这种数据结构的内存分配方式了。动态内存分配不需要预先分配存储空间,而是由系统根据程序的需要即时分配,且分配的大小就是程序要求的大小,实现弹性伸缩

      (3.)能够快速插入和移除表上任意位置上的节点,不需要移动大量元素,而这一点是数组无法匹敌的。

      这些优点也说明了链表存在的意义,当然,链表的局限性也是明显的:

      读取数据不能像数组一样按索引随机读取,必须顺序引导查找。

      针对数组和链表,实际应用时,需根据各自的特点及使用场景进行选用。如果能精确预测栈或者队列所需要容纳的数据量,就使用数组,否则宜使用链表。实际上,常见的数据结构也是这么选用的,这里列举如下:

数据结构

实现方式

栈 

数组/单链表

队列 

数组/双端链表

优先级队列

数组/堆/有序链表

双端队列

双向链表


      可见合理搭配数据结构、尽量发挥数组和链表各自的优点物尽其用才是王道。

3. 从哪些方面来讲述链表

      喷完了各种面试,我们也要言归正传,好好学习这门基础,毕竟猿们还要混口饭吃,除非自己咋了饭碗。那么会整理哪些链表知识呢?

       我将针对常用的链表类型:单链表、双向链表循环链表讨论面试常见的链表知识,包括链表创建、逆序、合并、节点插入、删除、查找等操作以及相关算法,力保能够涵盖链表问题的方方面面。

4. 链表链你妹系列文章索引

      本篇只是起头,后面将陆续补齐相关文章,并在此文中更新链接。文章风格嘛,还是尝试调侃为上的原则,知识不都是玩出来的吗,正所谓兴趣是最好的苍老师!^_^


      

      
        1.关于链表,不得不吐槽的那些事




     ---------------------------------------------------------------------------------------------------------------------------------------

       如果还喜欢,可以通过以下方式关注我哟:

          github    :    applefly

       微信公众号:   qi_chuang

       微           博:   心灯一豆







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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值