服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - C/C++ - C++链表节点的添加和删除介绍

C++链表节点的添加和删除介绍

2022-08-14 10:47与C决战的小萝卜头 C/C++

大家好,本篇文章主要讲的是C++链表节点的添加和删除介绍,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下,方便下次浏览

前言

链表是一种动态的数据结构,因为在创建链表时,不需要知道链表的长度,只需要对指针进行操作。

1. 节点的创建

链表的节点包括两部分,分别是:数据域和(指向下一个节点的)指针域。

?
1
2
3
4
struct Node {
    int data;
    struct Node* next;
};

2. 链表的定义

?
1
2
3
4
5
6
struct Node* createList() {
    //创建一个指针来表示表头
    struct Node* headNode = (struct Node*)malloc(sizeof(struct Node));
    headNode->next = NULL;
    return headNode;
}

3. 创建节点

?
1
2
3
4
5
6
7
8
struct Node* createNode(int data) {
    //创建一个新的指针节点
    struct Node* newNode = (struct Node*)malloc(sizeof(struct Node));
    //结构体变量初始化
    newNode->data = data;
    newNode->next = NULL;
    return newNode;
}

4. 节点的插入

节点的插入分为三种:头插法、尾插法、在链表中间插入节点。

 4.1 头插法

头插法,顾名思义就是在链表的第一个节点插入一个节点。

解决方法:让新插入的节点的next指针指向链表的头结点即可。

?
1
2
3
4
5
void insertNodeByHead(struct Node* headNode, int data) {
    struct Node* newNode = createNode(data);
    newNode->next = headNode->next;
    headNode->next = newNode;
}

 4.2 尾插法

尾插法,顾名思义就是在链表的末尾增加一个节点。

解决思路:首先找到链表的最后一个节点;然后让最后的节点的next指针指向要插入的这个节点,插入的节点的next指针指向NULL即可。

?
1
2
3
4
5
6
7
8
9
void insertNodeByTail(struct Node* headNode, int data) {
    struct Node* newNode = createNode(data);
    while (headNode->next != NULL)
    {
        headNode = headNode->next;//找到最后一个节点
    }
    headNode->next = newNode;
    newNode->next = NULL;
}

 4.3 插入中间节点

插入中间节点:即在数据为 i 的节点后面添加新的节点。

解决思路:首先判断数据为 i 的节点posNode是否在链表中存在;然后从第一个节点开始查找节点posNode。找到后就让插入的节点的next指针指向posNode的下一个节点,posNode的next指针指向新插入的节点即可。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
void insertNodeByCenter(struct Node* headNode, int data, int i) {
    struct Node* posNode = headNode;
    /*struct Node* posNodeFront = headNode;*/
    struct Node* newNode = createNode(data);
    if (posNode == NULL) {
        printf("无法查找此数据,链表为空\n");
    }
    else {
        while (posNode->data != i) {
            posNode = posNode->next;//前面位置到达了后面节点的位置
            /*posNode = posNodeFront->next;*///后面位置变成了原来位置的下一个
            if (posNode == NULL) {
                printf("未找到此数据\n");
                break;
            }
        }
        newNode->next = posNode->next;
        posNode->next = newNode;
    }
}

 总结

到此这篇关于C++链表节点的添加和删除介绍的文章就介绍到这了,更多相关C++链表节点内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/qq_47635065/article/details/122388071

延伸 · 阅读

精彩推荐
  • C/C++C++OOP对象和类的详细讲解

    C++OOP对象和类的详细讲解

    这篇文章主要介绍了C++面相对象编程中的类与对象的特性与概念,OOP面向对象语言相对C语言这样面相过程的语言来说具有类和对象以及方法这样的特性,需要...

    _Chrome_4542021-12-21
  • C/C++Linux中使用C语言的fork()函数创建子进程的实例教程

    Linux中使用C语言的fork()函数创建子进程的实例教程

    fork是一个在Linux系统环境下专有的函数,现有的进程调用fork后将会创建一个新的进程,这里我们就来看一下Linux中使用C语言的fork()函数创建子进程的实例教程...

    Jeakon12912021-04-07
  • C/C++MFC自定义消息的实现方法

    MFC自定义消息的实现方法

    这篇文章主要介绍了MFC自定义消息的实现方法,通过该示例可以更好的理解MFC的消息封装机制,以便更加灵活的打造个性化的windows应用程序,需要的朋友可以...

    C语言程序设计6252021-01-22
  • C/C++Linux系统下如何使用C++解析json文件详解

    Linux系统下如何使用C++解析json文件详解

    JSON(JavaScript Object Notation, JS 对象简谱) 是一种轻量级的数据交换格式。下面这篇文章主要给大家介绍了关于Linux系统下如何使用C++解析json文件的相关资料,需...

    Overboom6192021-11-11
  • C/C++C语言静态链表和动态链表

    C语言静态链表和动态链表

    静态链表和动态链表是线性表链式存储结构的两种不同的表示方式。静态链表的初始长度一般是固定的,在做插入和删除操作时不需要移动元素,仅需修改...

    web10137142021-04-01
  • C/C++C语言实现二叉树遍历的迭代算法

    C语言实现二叉树遍历的迭代算法

    这篇文章主要介绍了C语言实现二叉树遍历的迭代算法,包括二叉树的中序遍历、先序遍历及后序遍历等,是非常经典的算法,需要的朋友可以参考下...

    C语言程序设计11352021-02-03
  • C/C++C语言实现选择排序、直接插入排序、冒泡排序的示例

    C语言实现选择排序、直接插入排序、冒泡排序的示例

    这篇文章主要介绍了C++实现选择排序、直接插入排序、冒泡排序的代码示例,相当简洁直观,也是算法和数据结构学习中的基础,需要的朋友可以参考下...

    Newerth12182021-03-25
  • C/C++VC++实现通过API来查看程序错误信息的方法

    VC++实现通过API来查看程序错误信息的方法

    这篇文章主要介绍了VC++实现通过API来查看程序错误信息的方法,非常实用的功能,需要的朋友可以参考下...

    C++教程网12312021-01-27