首页 > 其他分享 >链表基础知识

链表基础知识

时间:2022-11-30 09:33:20浏览次数:40  
标签:ListNode val 基础知识 链表 next 节点 指针

1.什么是链表

    链表是一种通过指针串联在一起的线性结构,每一个节点由两部分组成,一个是数据域一个是指针域(存放指向下一个节点的指针),最后一个节点的指针域指向null(空指针的意思)。链接的入口节点称为链表的头结点也就是head。

     

2.链表的类型

2.1单链表

    见上图

2.2双链表

    单链表中的指针域只能指向节点的下一个节点。双链表:每一个节点有两个指针域,一个指向下一个节点,一个指向上一个节点。双链表既可以向前查询也可以向后查询。

    

2.3循环链表

    循环链表,顾名思义,就是链表首尾相连。循环链表可以用来解决约瑟夫环问题。

     

3.链表存储方式

    数组是在内存中是连续分布的,但是链表在内存中可不是连续分布的。链表是通过指针域的指针链接在内存中各个节点。所以链表中的节点在内存中不是连续分布的 ,而是散乱分布在内存中的某地址上,分配机制取决于操作系统的内存管理。

    

 

4.链表的定义(需要关注)

    链表节点的定义,很多同学在面试的时候都写不好。这是因为平时在刷leetcode的时候,链表的节点都默认定义好了,直接用就行了,所以同学们都没有注意到链表的节点是如何定义的。而在面试的时候,一旦要自己手写链表,就写的错漏百出。

// 单链表
struct ListNode {
    int val;  // 节点上存储的元素
    ListNode *next;  // 指向下一个节点的指针
    ListNode(int x) : val(x), next(NULL) {}  // 节点的构造函数
};

    java定义如下:

public class ListNode {
    // 结点的值
    int val;
    // 下一个结点
    ListNode next;
    // 节点的构造函数(无参)
    public ListNode() {
    }

    // 节点的构造函数(有一个参数)
    public ListNode(int val) {
        this.val = val;
    }

    // 节点的构造函数(有两个参数)
    public ListNode(int val, ListNode next) {
        this.val = val;
        this.next = next;
    }
}

5.链表的操作(重点)

5.1删除节点

    删除D节点,只要将C节点的next指针指向E节点就可以了。在C++里最好是再手动释放这个D节点,释放这块内存。其他语言例如Java、Python,就有自己的内存回收机制,就不用自己手动释放了。    

5.2添加节点

    可以看出链表的增添和删除都是O(1)操作,也不会影响到其他节点。但是要注意,要是删除第五个节点,需要从头节点查找到第四个节点通过next指针进行删除操作,查找的时间复杂度是O(n)。

    

6性能分析

    把链表的特性和数组的特性进行一个对比,如图所示:

    

    数组在定义的时候,长度就是固定的,如果想改动数组的长度,就需要重新定义一个新的数组。链表的长度可以是不固定的,并且可以动态增删, 适合数据量不固定,频繁增删,较少查询的场景。

 

 内容来自代码随想录!!!

 

标签:ListNode,val,基础知识,链表,next,节点,指针
From: https://www.cnblogs.com/lzdream/p/16927796.html

相关文章

  • 双向链表
    双向链表介绍因为在循环链表中某一结点要访问其前驱结点的时候,需要循环扫描整个链表一遍,效率太低了。为了方便访问结点的前驱结点,我们引入了双向链表的概念。原本一个结......
  • 双链表
    //e[]表示节点的值,l[]表示节点的左指针,r[]表示节点的右指针,idx表示当前用到了哪个节点inte[N],l[N],r[N],idx;//初始化voidinit(){//0是左端点,1是右端点......
  • 链表-双向链表
    在双向链表中,除了下一个节点链接之外,每个节点还包含指向序列中“前一个”节点的第二个链接字段。这两个链接可以称为'forward('s')和'backwards',或'next'和'prev'('previous......
  • Kotlin系列一:基础知识快速入门
    目录​​一概述​​​​二基本类型​​​​2.1 数字​​​​2.2 字符类型​​​​2.3 布尔型​​​​2.4 数组类型​​​​2.5 字符串​​​​三类型转换和变量定义......
  • 相交链表
    160.相交链表由题目要求可以知道,题目数据保证了不会出现环形注意,函数返回结果后,链表必须保持其原始结构。方法一:哈希集合利用哈希表的特性,不能放重复元素判断两个链......
  • 单向循环链表-约瑟夫问题
    单向环形列表应用场景:约瑟夫环问题思路:创建第一个节点,让first指向该节点,并形成环状后面当我们每创建一个新的节点,就把该节点,加入到已有的环形链表中即可遍历环形链......
  • C#面试题 算法 --- 2 单链表倒置
    classNode{publicobjectdata;publicNodenext;publicNode(objectdata){this.data=data;}} ///......
  • java泛型机制(基础知识总结篇)
    泛型概述泛型使用的必要性泛型类泛型接口泛型对象引用传递的解决方案泛型方法泛型的简单应用---本文中将介绍泛型的基础知识以及简单应用,后面还计划......
  • 第一周,链表、栈、队列
    第一周,链表、栈、队列206.反转链表方法一:双指针法:定义两个指针:pre和cur每次让pre的next指向cur,实现一次局部反转局部反转完成之后,pre和cur同时往前移动......
  • 带头链表的实现
    packagelinkedListimport"fmt"/**go实现带头单链表基本操作*/typeListNodestruct{ valueinterface{} next*ListNode}typeLinkedListstruct{ head......