链表基本结构及操作实现详解

本文详细介绍了链表的基础知识,包括单向链表和双向链表的节点定义、线性和环形结构的实现。重点讲解了链表中添加、删除节点的操作,如在尾部、中间添加和删除节点,以及在双向链表中的相应操作。
摘要由CSDN通过智能技术生成

单向链表

节点

templat <typename T>
struct Node {
   
    T value;
    Node* next;
    Node(const T& val = 0, Node* nextnode = nullptr): value(val), next(nextnode) {
   
        if (value) {
   
            cout << "成功插入 " << value << " 到链表中\n";
        }
    }
};

单向线性链表

在这里插入图片描述

实现

template <typename T>
class List {
   
public:
    List() : head(new Node<T>) {
   }  //给头节点分配新内存至关重要
    void CreateList(int number) {
   
        if (number <= 0) return;
        T val;
        Node<T>* temp = head;
        while (--number >= 0) {
   
            cin >> val;
            Node<T>* nextnode = new Node<T>(val);
            temp->next = nextnode;
            temp = nextnode;
        }
    }
 
private:
    Node<T>* head;
};
 
MyList.CreateList(n);
//这里可以写成成员函数,那样就可以private head指针了
for (auto i = MyList.head->next; i != nullptr; i = i->next) {
   
    cout << i->value << " ";
}

单向链表的操作

添加到尾结点

在这里插入图片描述

template <typename T>
void List<T>::insert_to_end(Node<T>* node) {
   
    Node<T>* temp = head;
    while (temp->next != nullptr) {
   
        temp = temp->next;
    }
    temp->next = node;
}
添加到中间结点

在这里插入图片描述

template <typename T>
void List<T>::insert_to_medium(int pos, Node<T>* node) {
   
    int i = 0;
    Node<T>* temp = head;
    while (++i < pos && temp->next != nullptr) {
   
        temp = temp->next;
    }
    node->next = temp->next;
    temp->next = node;
}
删除链表的尾结点

在这里插入图片描述

template <typename T>
void List<T>::del_endNode() {
   
    Node<T>*prev = nullptr, *temp = head;
    while (temp->next != nullptr) {
   
        prev = temp;
        temp = temp->next;
    }
    delete temp;
    prev->next = nullptr;
}
删除链表的中间结点

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值