首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

linux 单向链表

基础概念

单向链表(Singly Linked List)是一种线性数据结构,其中每个元素(称为节点)包含一个数据域和一个指针域。这个指针域指向链表中的下一个节点。链表的第一个节点称为头节点(head),最后一个节点的指针域指向空(NULL),表示链表的结束。

优势

  1. 动态内存分配:链表在运行时动态分配内存,不需要预先知道数据的大小。
  2. 插入和删除操作高效:在链表中插入或删除节点只需要改变相邻节点的指针,时间复杂度为O(1)(假设已经找到要插入或删除的位置)。
  3. 内存利用率高:链表不需要连续的内存空间,可以更灵活地利用内存。

类型

  1. 单链表:每个节点只有一个指向下一个节点的指针。
  2. 双链表:每个节点有两个指针,一个指向前一个节点,一个指向后一个节点。
  3. 循环链表:最后一个节点的指针指向第一个节点,形成一个环。

应用场景

  1. 动态数据存储:当数据量不确定或需要频繁插入和删除操作时,链表是一个很好的选择。
  2. 实现栈和队列:链表可以用来实现栈和队列等数据结构。
  3. 内存管理:链表可以用于管理动态分配的内存块。

示例代码

以下是一个简单的单链表实现,包括节点定义和基本操作(插入、删除、遍历):

代码语言:txt
复制
#include <stdio.h>
#include <stdlib.h>

// 定义链表节点结构
struct Node {
    int data;
    struct Node* next;
};

// 创建新节点
struct Node* createNode(int data) {
    struct Node* newNode = (struct Node*)malloc(sizeof(struct Node));
    newNode->data = data;
    newNode->next = NULL;
    return newNode;
}

// 在链表头部插入节点
void insertAtHead(struct Node** head, int data) {
    struct Node* newNode = createNode(data);
    newNode->next = *head;
    *head = newNode;
}

// 删除链表中的节点(假设节点存在)
void deleteNode(struct Node** head, int key) {
    struct Node* temp = *head;
    struct Node* prev = NULL;

    if (temp != NULL && temp->data == key) {
        *head = temp->next;
        free(temp);
        return;
    }

    while (temp != NULL && temp->data != key) {
        prev = temp;
        temp = temp->next;
    }

    if (temp == NULL) return;

    prev->next = temp->next;
    free(temp);
}

// 遍历并打印链表
void printList(struct Node* node) {
    while (node != NULL) {
        printf("%d -> ", node->data);
        node = node->next;
    }
    printf("NULL\n");
}

int main() {
    struct Node* head = NULL;

    insertAtHead(&head, 3);
    insertAtHead(&head, 2);
    insertAtHead(&head, 1);

    printf("Linked List:\n");
    printList(head);

    deleteNode(&head, 2);

    printf("After deleting 2:\n");
    printList(head);

    return 0;
}

参考链接

常见问题及解决方法

  1. 内存泄漏:在删除节点时,确保释放了相应的内存。
  2. 内存泄漏:在删除节点时,确保释放了相应的内存。
  3. 空指针引用:在访问节点的next指针之前,确保节点不为空。
  4. 空指针引用:在访问节点的next指针之前,确保节点不为空。
  5. 链表遍历错误:在遍历链表时,确保正确处理头节点和尾节点的情况。
  6. 链表遍历错误:在遍历链表时,确保正确处理头节点和尾节点的情况。

通过以上内容,你应该对Linux下的单向链表有了全面的了解,包括其基础概念、优势、类型、应用场景以及常见问题的解决方法。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

C 单向链表排序_单向链表排序java

链表排序 链表排序的两种方式 一、交换结点的数据域 二、断开链表,重新形成 方法 示例 链表排序的两种方式 一、交换结点的数据域 有很多种方法,比如冒泡排序,选择排序等其他排序方法...,重新形成 方法 跟三指针法反转链表类似,也是要定义三个结构体指针。...第一步: 第一个指针用于找最小值 第二个指针用于指向最小值的前一个结点 第三个指针用于遍历链表 第二步: 让最小值从链表当中脱离出来 第三步: 然后再定义一个新的指针,用头插法把指向最小值的指针...形成新的链表,通过调整新链表结点的插入方法和在原链表找最值得到升序或降序的效果。...) //结点数据域比较 { pMin_prev = p; //标记 pMin = p->next; } p = p->next; } //2、将最值结点脱离出原链表 if(pMin == head)

64440
  • 单向链表

    在做缓存设计的时候,可以用到链表的数据结构来做缓存设计。主体结构采用map,而存储的节点、数据采用双向链表。这里介绍单向链表,因为如果搞懂了单向链表,其实双向链表更好理解。...数据结构中的链表分为单向链表、双向链表、循环链表。...单向链表的数据结构中通常会存在数据域和节点域: 如图1:单向链表的数据结构 public class LinkNode{ int value; // 数据域 LinkNode next; //...双向链表:存在前驱节点和后继节点,基于前驱和后继节点可以很方便的表示节点元素间的关系。可以看到与单向链表不同的是存在的节点有前驱节点,同时是双向的。 ?...考虑单向链表中 一种情况:当前节点只有一个节点或者当前的节点与下一个节点不同时,此时进行节点指向。

    47820

    反转单向链表

    单向链表的反转是一个非常常见的链表类面试题,我在刷leetcode的过程中,发现了有许多链表题目的解法,都是以反转链表为基础进行的。所以我觉得有必要记录一下。 首先先用一张图来理解单链表的反转。 ?...image 单链表的反转,就如上图一样,而单链表的反转也有几种方式,今天我主要是想记录我用得最频繁的迭代的方式。...先来看一下链表节点的定义: public class ListNode { int val; ListNode next; ListNode(int x) { val = x;...} } 这就是最基础的一个链表节点,而反转链表的代码,其实非常的短,关键点就在于理解这几行代码究竟让链表产生了什么变化。...这样说起来确实有点拗口,但是我推荐大家在做链表类题目和理解链表的具体行为时,用一张纸和笔来辅助自己写写画画,相信很快你就会弄懂链表的具体思路的。

    66510

    Linux C 数据结构 ->单向链表

    之前看到一篇单向链表的博文,代码也看着很舒服,于是乎记录下来,留给自己~,循序渐进,慢慢   延伸到真正的内核链表~(敢问路在何方?路在脚下~)   1....简介   链表是Linux 内核中最简单,最普通的数据结构。...链表是一种存放和操作可变数量元素(常称为节点)   的数据结构,链表和静态数组的不同之处在于,它所包含的元素都是动态创建并插入链表的,在编译   时不必知道具体需要创建多少个元素,另外也因为链表中每个元素的创建时间各不相同...根据它的特性,链表可分为:单链表,双链表,单向循环链表和双向循环链表,今天总结记录的就是   最简单的单链表,   1.1 节点类型描述   1 typedef struct node_t {   ...链表基本运算的相关"算法"操作 or 操刀(~烹羊宰牛且为乐,会须一饮三百杯~)   链表的运算除了上面的创建空链表,还有数据的插入,删除,查找等函数,链表的运算有各种实现方   法,如何写出一个高效的

    1.1K00

    单向链表漫谈

    相爱相杀好基友——数组与链表 作为线性表的两种存储方式 —— 链表和数组,这对相爱相杀的好基友有着各自的优缺点。接下来,我们梳理一下这两种方式。...链表,由若干个结点组成,每个结点包含数据域和指针域。结点结构如下图所示: 一般来讲,链表中只会有一个结点的指针域为空,该结点为尾结点,其他结点的指针域都会存储一个结点的内存地址。...链表中也只会有一个结点的内存地址没有存储在其他结点的指针域,该结点称为头结点。 链表的存储方式使得它可以高效的在指定位置插入与删除,时间复杂度均为 O(1)。...设链表有 n 个元素,那么最多移动 n/2 轮。...根据上述表述得出,如果一个链表存在环,那么快慢指针必然会相遇。

    42900

    Python 实现单向链表,和单向链表的反转

    链表的定义链表中的每个节点会存储相邻节点的位置信息,单链表中的每个节点只存储下一关节点的位置信息单向链表的实现python 代码解读复制代码class ListNode: def __init__...(self, val): self.val = val self.next = None要实现单向链表只需要把几个节点关联起来就可以了,把一个节点的next设置为另一个节点就可以了...,例如创建一个A->B->C 的单向链表可以这么写:python 代码解读复制代码 first_node = ListNode("A") second_node = ListNode("B") third_node...= ListNode("C") first_node.next = second_node second_node.next = third_noefirst_node 就是这个链表的表头,他们3个一起组成了一个单向链表单向链表反转...first_node 传进去:python 代码解读复制代码solution = Solution()result = solution.reverse(first_node)如果你想查看这个链表的内容顺序

    2700

    JavaScript实现单向链表

    数组开头或者中间位置插入数据的成本很高,需要进行大量元素的位移 链表的优势 不同于数组,链表中的元素在内存中不必时连续的空间 链表的每个元素由一个存储元素本身的节点和指向下一个元素的引用(有些语言称为指针或者连接...链表是什么?...链表中的常见操作: 添加: append(element):向链表尾部添加一个新的项; insert(position,element):向链表的特定位置插入一个新的项; 获取: get(position...element):从链表中移除一项; 其他: isEmpty():如果链表中不包含任何元素,返回trun,如果链表长度大于0则返回false,判断是否为空链表; size():返回链表包含的元素个数,与数组的...向链表尾部追加数据可能有两种情况: 链表本身为空,新添加的数据时唯一的节点.

    9010

    Java 单向链表学习

    Java 单向链表学习 链表等同于动态的数组;可以不同设定固定的空间,根据需要的内容动态的改变链表的占用空间和动态的数组同一形式;链表的使用可以更加便于操作。...链表的基本结构包括:链表工具类和节点类,节点类是工具类的内部类,这样可以便于Link和Node类之间的属性调用和方法使用,也有效的封装了Node类不被外部所使用; Link类主要负责处理外部类和Node...类之间的关系以及链表内容的存储;Node类负责具体的链表结构的操作,比如:添加链表时需要将新的链表放在上一个链表的后面则需要Link调用Node类进行链表结构的定义,同理:大多链表结构的操作都有Node...链表结构中:root负责记录链表首结构的地址,next负责记录当前链表节点的下一个链表节点的地址,data则是记录具体的数据类型的数据信息。...;可以将存入的数据按照链表存储(顺序方法)。

    92710

    JavaScript数据结构(3-1):单向链表与双向链表——单向链表篇

    随着时间的推移,我终于发现了一个能够准确类比单链表和双向链表的例子:寻宝游戏。 如果你对寻宝游戏和链表之间的关系感到好奇,请继续往下读。...现在我们对单链表有了一个基本的概念,接下来讨论单链表的操作 单链表的操作 因为单链表包含节点,这两者的构造函数可以是两个独立的构造函数,所以我们需要些构造函数:Node 和 SinglyList Node...第一种情况考虑将节点添加到空的链表中,如果head没有指向任何节点的话,那么将该node指定为链表的头,同时链表的长度加一,并返回node。 第二种情况考虑将节点添加到飞空链表。...单向链表的完整实现 以下是单向链表的完整实现: function Node(data) { this.data = data; this.next = null;} function..._length--; return deletedNode; }; 请等待本系列的第三篇文章:《JavaScript 数据结构(3):单向链表与双向链表》

    70430
    领券