码迷,mamicode.com
首页 > 其他好文 > 详细

双向链表

时间:2019-09-22 10:39:34      阅读:91      评论:0      收藏:0      [点我收藏+]

标签:ima   自我   一个   heron   inf   方式   示意图   mda   image   

双向链表

  管理单向链表的缺点分析

    1、单向链表,查找的方法只能是一个方向,而双向链表可以向前或者向后查找

    2、单线链表不能自我删除,需要靠辅助节点,而双向链表,则可以自我删除。

   应用实例:使用带 head 头的双向链表实现 — 水浒英雄排行榜  

   双向链表如何完成遍历,添加,修改和删除的思路示意图:

技术图片

 

 

    对上图的说明:

  (1)遍历方式同单链表一样,可以向前遍历,也可以向后查找

  (2)添加(默认添加到双向链表的最后)

    ① 先找到双向链表的最后这个节点temp

    ② temp.next = newHeroNode;

    ③ newHeroNode.pre = temp;

  (3)修改思路同单向链表一样 

  (4)删除 

    ① 因为是双向链表,可以实现自我删除某个节点

    ② 直接找到要删除的这个节点,比如temp

    ③  temp.pre.next = temp.next;

    ④ temp.next.pre = temp.pre;(注意:这里需要分析看看temp是否为最后一个节点,如果则不需要这句话)

  (5)第二种添加方式,按照编号顺序添加

     代码实现:

 

双向链表

标签:ima   自我   一个   heron   inf   方式   示意图   mda   image   

原文地址:https://www.cnblogs.com/niujifei/p/11565886.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!