LeetCodeHot100|链表总结

最近把leetcode的链表刷完了,所以想着来写一个关于链表的小结

刷过的题目表

相交链表、反转链表、回文链表、环形链表、环形链表二、两个合并有序链表、删除链表的倒数第N个结点、两两交换链表中的节点、K个一组翻转链表、随机链表的复制、排序链表、LRU缓存

这些都是关于链表的题目,在刷完这些题目之前,再来对对链表的基础知识做一个总结回顾,链表的这些操作是必须要会的,分别是初始化链表,插入节点,删除节点,访问节点,查找节点。首先来看如何初始化链表。

这里有一张链表和数组在内存中存储的图,方便大家理解。

初始化链表

cpp 复制代码
/* 初始化链表 1 -> 3 -> 2 -> 5 -> 4 */
// 初始化各个节点
ListNode* n0 = new ListNode(1);
ListNode* n1 = new ListNode(3);
ListNode* n2 = new ListNode(2);
ListNode* n3 = new ListNode(5);
ListNode* n4 = new ListNode(4);
// 构建节点之间的引用
n0->next = n1;
n1->next = n2;
n2->next = n3;
n3->next = n4;

从这里可以看出,构建链表主要是通过两步,第一步是构建各个节点,第二步是构建各个节点之间的引用。

插入节点

cpp 复制代码
// 在链表n0之后插入节点 P
void insert(ListNode* n0,ListNode *p) { 
    ListNode *n1 = n0 ->next; 
    p->next = n1;
    n0 ->next = p;
}

入上图所示,如果想在两个节点之间插入一个节点的话,需要改变两个指针的指向,分别是修改n0和p指针的指向,在n0与n1之间插入,时间复杂度为O(1)

删除节点

cpp 复制代码
/* 删除链表的节点 n0 之后的首个节点 */
void remove(ListNode *n0) {
    if (n0->next == nullptr)
        return;
    // n0 -> P -> n1
    ListNode *P = n0->next;
    ListNode *n1 = P->next;
    n0->next = n1;
    // 释放内存
    delete P;
}

如上图所示,在链表中删除节点,只需要改变一个节点的引用(指针)即可

,虽然节点P仍然指向n1,但是遍历的时候已经找不到它了。

访问节点

cpp 复制代码
// 访问链表中索引为 index 的节点
ListNode *access(ListNode *head, int index) { 
    for(int i = 0; i < index;i++) { 
        if(head == nullptr)
            return nullptr;
        head = head -> next;
    }
    return head;
}

在数组访问元素的时间复杂度是O(1),但是在链表中访问元素的复杂度为O(n),访问节点的效率低。程序在访问时需要从头节点出发,逐个往后便利,直到找到目标节点,也就是访问第i个节点需要i-1轮,时间复杂度为O(n).链表在内存中的真实布局类似下图.

查找节点

cpp 复制代码
// 在链表中查找值为 target的首个节点
int find(ListNode *head, int taget) { 
    int index = 0;
    while( head != nullptr) { 
        if(head -> val == target)
            return index;
        head = head -> next;
        index++;
    }
    return -1;
}

查找值为target 的节点,输出改节点在链表中的索引,这个过程也属于线性查找。了解完这些之后链表的一些基础操作就都知道了,前面讲的都是单向链表,其实链表还有其他的类型,比如环形链表,以及双向链表,如下图所示。

相关推荐
森G11 小时前
48、柱状图---------QChart
c++·qt
charliejohn11 小时前
计算机考研 408 数据结构 排序算法
数据结构
Tanecious.11 小时前
蓝桥杯备赛:Day8-小苯的异或和
c++·蓝桥杯
王老师青少年编程11 小时前
csp信奥赛c++中的递归和递推研究
c++·算法·递归·递推·csp·信奥赛
汀、人工智能11 小时前
[特殊字符] 第36课:柱状图最大矩形
数据结构·算法·数据库架构·图论·bfs·柱状图最大矩形
样例过了就是过了11 小时前
LeetCode热题100 跳跃游戏
c++·算法·leetcode·贪心算法·动态规划
chen_ever11 小时前
从网络基础到吃透 Linux 高并发 I/O 核心(epoll+零拷贝 完整版)
linux·网络·c++·后端
无限进步_12 小时前
【C++&string】寻找字符串中第一个唯一字符:两种经典解法详解
开发语言·c++·git·算法·github·哈希算法·visual studio
小此方12 小时前
Re:思考·重建·记录 现代C++ C++11篇 (二) 右值引用与移动语义&引用折叠与完美转发
开发语言·c++·c++11·现代c++
LG.YDX12 小时前
笔试训练48天:跳台阶
数据结构·算法