数据结构—双向链表

简介: 数据结构—双向链表

1.  链表的种类

由上面的组合可以知道链表由2^3种类型


2.  最实用的两种链表类型

2.1 单向不带头不循环链表—(之前博客实现了)

     

2.2 双向带头循环链表


3. 实现双向带头循环链表

       3.1 创建头节点

LTNode* BuyListNode(LTDataType x)
{
  LTNode* node = (LTNode*)malloc(sizeof(LTNode));
  if (node == NULL)
  {
    perror("malloc fail");
    exit(-1);
  }
  node->data = x;
  node->next = NULL;
  node->prev = NULL;
  return node;
}

  3.2 实现双向循环功能—返回头指针

LTNode* ListInit()
{
  LTNode* phead = BuyListNode(-1);//给头的data随便给个初始值
  phead->next = phead;
  phead->prev = phead;
  return phead;
}

   3.3  尾插  

void ListPushBack(LTNode* phead, LTDataType x)
{
  assert(phead);
  LTNode* newnode = BuyListNode(x);
  LTNode* tail = phead->prev;
  tail->next = newnode;
  newnode->prev = tail;
  newnode->next = phead;
  phead->prev = newnode;
  //ListInsert(phead, x);
}


   3.4 头插

void ListPushFront(LTNode* phead, LTDataType x)
{
  assert(phead);
  LTNode* newnode = BuyListNode(x);
  LTNode* next = phead->next;
    phead newnode next
  phead->next = newnode;
  newnode->prev = phead;
  newnode->next = next;
  next->prev = newnode;
  //ListInsert(phead->next, x);
}


  3.5 尾删

void ListPopBack(LTNode* phead)
{
  assert(phead);
  assert(phead->next != phead);
  //assert(!ListEmpty(phead));
  LTNode* tail = phead->prev;
  LTNode* tailPrev = tail->prev;
  free(tail);
  tailPrev->next = phead;
  phead->prev = tailPrev;
  //ListErase(phead->prev);
}


   3.6 头删

void ListPopFront(LTNode* phead)
{
  assert(phead);
  assert(phead->next != phead);
  ListErase(phead->next);
}

4 实现两个重要接口函数

 随机插入接口函数(ListInsert)可以实现头插、尾插,直接复用

随机删除接口函数(ListErase)可以实现头删、尾删,直接复用



    4.1 随机插入

void ListInsert(LTNode* pos, LTDataType x)
{
  assert(pos);
  LTNode* prev = pos->prev;
  LTNode* newnode = BuyListNode(x);
  // prve newnode pos
  prev->next = newnode;
  newnode->prev = prev;
  newnode->next = pos;
  pos->prev = newnode;
}

4.2 随机删除

void ListErase(LTNode* pos)
{
  assert(pos);
  LTNode* prev = pos->prev;
  LTNode* next = pos->next;
  prev->next = next;
  next->prev = prev;
  free(pos);
}

5  顺序表和链表总结


相关文章
|
18天前
|
缓存
数据结构之 - 链表数据结构详解: 从基础到实现
数据结构之 - 链表数据结构详解: 从基础到实现
53 6
|
18天前
|
存储 算法 搜索推荐
探索常见数据结构:数组、链表、栈、队列、树和图
探索常见数据结构:数组、链表、栈、队列、树和图
84 64
|
12天前
|
存储 Java
数据结构第三篇【链表的相关知识点一及在线OJ习题】
数据结构第三篇【链表的相关知识点一及在线OJ习题】
21 7
|
12天前
|
存储 安全 Java
【用Java学习数据结构系列】探索顺序表和链表的无尽秘密(附带练习唔)pro
【用Java学习数据结构系列】探索顺序表和链表的无尽秘密(附带练习唔)pro
18 3
|
11天前
|
算法 Java
数据结构与算法学习五:双链表的增、删、改、查
双链表的增、删、改、查操作及其Java实现,并通过实例演示了双向链表的优势和应用。
10 0
数据结构与算法学习五:双链表的增、删、改、查
【数据结构】——双向链表详细理解和实现
【数据结构】——双向链表详细理解和实现
|
15天前
|
存储 Java
【数据结构】链表
【数据结构】链表
14 1
|
16天前
|
存储 缓存
数据结构3——双向链表
数据结构3——双向链表
72 1
|
5天前
|
存储
[数据结构] -- 双向循环链表
[数据结构] -- 双向循环链表
12 0
|
10天前
|
存储
探索数据结构:便捷的双向链表
探索数据结构:便捷的双向链表