【c++】用c++实现带头双向循环链表

简介: 【c++】用c++实现带头双向循环链表

我们之前用c语言实现了双向带头循环链表

带头双向循环链表的实现-CSDN博客

本文我们用c++实现

#define _CRT_SECURE_NO_WARNINGS 1
#include<iostream>
using namespace std;
struct Node
{
  int _val;
  struct Node* _prev;
  struct Node* _next;
  Node(int x = -1)
  {
    _val = x;
    _prev = nullptr;
    _next = nullptr;
  }
  ~Node()
  {}
};
class LTNode
{
public:
  LTNode()
  {
    head = new Node();
    head->_prev = head;
    head->_next = head;
  }
  ~LTNode()
  {
 
  }
  void LTPushBack(int val)
  {
    Node* tmp = new Node(val);
    if (isEmpty())
    {
      head->_next = tmp;
      tmp->_next = head;
      head->_prev = tmp;
      tmp->_prev = head;
    }
    else
    {
      Node* tail = head->_prev;
      tail->_next = tmp;
      tmp->_prev = tail;
      tmp->_next = head;
      head->_prev = tmp;
    }
  }
  void LTPushFront(int val)
  {
    Node* newnode = new Node(val);
    newnode->_next = head->_next;
    newnode->_prev = head;
    head->_next->_prev = newnode;
    head->_next = newnode;
  }
  void LTPopBack()
  {
    Node* tail = head->_prev;
    Node* tailprev = tail->_prev;
    delete tail;
    tailprev->_next = head;
    head->_prev = tailprev;
  }
  void LTPopFront()
  {
    Node* first = head->_next;
    Node* second = first->_next;
    head->_next = second;
    second->_prev = head;
    delete first;
  }
  bool isEmpty() const 
  {
    return (head->_next == head && head->_prev == head); // 判断链表是否为空
  }
  void Print()
  {
    Node* cur = head->_next;
    cout << "哨兵位<=>";
    while (cur != head)
    {
      cout << cur->_val << "<=>";
      cur = cur->_next;
    }
    cout << "哨兵位" << endl;
  }
  Node* LTFind(int x)
  {
    Node* cur = head->_next;
    while (cur != head)
    {
      if (cur->_val == x)
      {
        return cur;
      }
      cur = cur->_next;
    }
    return nullptr;
  }
  void LTInsert(Node* pos, int x)//在pos之前插入
  {
    Node* newnode = new Node(x);
    Node* posprev = pos->_prev;
 
    posprev->_next = newnode;
    newnode->_next = pos;
    newnode->_prev = posprev;
    pos->_prev = newnode;
  }
  void LTErase(Node* pos)
  {
    Node* posprev = pos->_prev;
    Node* posnext = pos->_next;
 
    posprev->_next = posnext;
    posnext->_prev = posprev;
    delete pos;
  }
private:
  Node* head;
};
int main()
{
  LTNode l1;
  l1.LTPushBack(1);
  l1.LTPushBack(2);
  l1.LTPushBack(3);
  l1.LTPushBack(4);
  l1.LTPushBack(4);
  l1.Print();
  l1.LTInsert(l1.LTFind(2), 2);
  l1.LTInsert(l1.LTFind(1), 0);
  l1.Print();
  l1.LTErase(l1.LTFind(0));
  l1.Print();
  l1.LTPushFront(0);
  l1.Print();
  l1.LTPopBack();
  l1.LTPopFront();
  l1.Print();
  return 0;
}

gitee:ListNode · mnxcc/cpp - 码云 - 开源中国 (gitee.com)

相关文章
|
6月前
|
C++
【链表】还不会用C++实现链表?一文教会你各种链表的实现
【链表】还不会用C++实现链表?一文教会你各种链表的实现
257 0
|
4月前
|
存储 C++
C++的list-map链表与映射表
```markdown C++ 中的`list`和`map`提供链表和映射表功能。`list`是双向链表,支持头尾插入删除(`push_front/push_back/pop_front/pop_back`),迭代器遍历及任意位置插入删除。`map`是键值对集合,自动按键排序,支持直接通过键来添加、修改和删除元素。两者均能使用范围for循环遍历,`map`的`count`函数用于统计键值出现次数。 ```
|
5月前
|
存储 C++
C++的list-map链表与映射表
这篇教程介绍了C++中`list`链表和`map`映射表的基本使用。`list`链表可通过`push_front()`、`push_back()`、`pop_front()`和`pop_back()`进行元素的添加和删除,使用迭代器遍历并支持在任意位置插入或删除元素。`map`是一个键值对的集合,元素自动按键值排序,可使用下标操作符或`insert()`函数插入元素,通过迭代器遍历并修改键值对,同时提供`count()`方法统计键值出现次数。教程中包含多个示例代码以帮助理解和学习。
|
6月前
|
算法 C++
c++算法学习笔记 (13) 链表
c++算法学习笔记 (13) 链表
|
5月前
|
C++ Python
UE C++ 链表
UE C++ 链表
|
5月前
|
C++ 容器
【C++进阶】深入STL之list:高效双向链表的使用技巧
【C++进阶】深入STL之list:高效双向链表的使用技巧
55 0
|
6月前
|
存储 缓存 C++
C++链表常用的函数编写(增查删改)内附完整程序
C++链表常用的函数编写(增查删改)内附完整程序
106 0
|
6月前
|
存储 算法 C语言
【C/C++ 链表结构】探索链表迭代器:C++实现的深入分析与优化策略
【C/C++ 链表结构】探索链表迭代器:C++实现的深入分析与优化策略
130 0
|
6月前
|
存储 算法 程序员
深入理解 C++ 自定义链表中实现迭代器
深入理解 C++ 自定义链表中实现迭代器
88 0
|
6月前
|
存储 算法 Linux
【C/C++ 线性表】C++ 从零开始实现 双向循环链表(Exploring Doubly Circular Linked List in C++)
【C/C++ 线性表】C++ 从零开始实现 双向循环链表(Exploring Doubly Circular Linked List in C++)
119 0