链表算法中常用操作和技巧

1.常用技巧

1.1.画图

1.2.添加虚拟头节点

1.3.大胆引入中间变量

1.4.快慢双指针

1.4.1判断链表是否有环

1.4.2找链表中环的入口

​2.常用操作

[2.1. 创建一个新节点](#2.1. 创建一个新节点)

2.2.尾插

2.3.头插


1.常用技巧

1.1.画图

画图可以让一些抽象的文字语言更加形象生动

画图!!!->直观+形象+便于我们理解

例如:

现在有一个结构体

复制代码
struct s
{
    struct s*pprev;
    struct s*pnext;
}

他们的的关系如下:

复制代码
prev->pnext->pnext=cur;
cur->pprev->prev=prev;
cur->pnext=prev;
prev->pprev=cur;

是不是感觉无从下手,但是我们只要转化为图形就能很好的理解:

1.2.添加虚拟头节点

在链表算法题中很多时候都会给我们传来的头节点为空情况,如果我们没有判断直接对空指针进行解引用,程序可能会直接崩溃:

如果我们能引入一个头节点,则可以避免直接对空指针解引用情况

这个头节点我们也会称作'哨兵位':

1.3.大胆引入中间变量

如果不引入中间变量

复制代码
prev->pnext->pprev=cur;
cur->pnext=prev->pnext;
prev->pnext=cur;
cur->pprev=prev;

引入中间变量next,代码更加干净整洁

复制代码
next=prev->pnext;
next->pprev=cur;
cur->pnext=next;
prev->pnext=cur;
cur->pprev=prev;

1.4.快慢双指针

1.4.1判断链表是否有环

  • 快指针(fast)一次走两步,慢指针(slow)一次走两步
  • 对有环的链表来说,慢指针相当于快指针不动,快指针相对慢指针一次一步
  • 对无环的链表来说,快指针会提前走出链表,让循环结束
  • 循环条件(fast==slow)有环,(fast->next==nullptr||fast->next->next==nullptr)无环

相遇:

1.4.2找链表中环的入口

  • 假设链表共有a+b个元素,从head(头节点)到圆环入口有a个元素,圆环有b个元素
  • 在有环基础上,两者相遇,快指针和慢指针分别走了f,s。f=2s(因为快指针是慢指针速度的两倍)
  • f=s+nb(fast比slow多走了n个圆环),所以f=2nb,s=nb
    • 固定此时相遇位置,slow从头开始再走一遍,slow到fast的位置就是圆环b的长度
    • **不固定此时相遇位置,**slow从头出发,fast从相遇位置出发,两者都每次走一步,两者再次相遇的位置即为圆环入口的位置

2.常用操作

2.1. 创建一个新节点

例如:创建一个head的指针

cpp 复制代码
s*head=new s();

2.2.尾插

cpp 复制代码
tail->next=cur;
cur=tail;

2.3.头插

cpp 复制代码
cur->next=head->next;
head->next=cur;

常用于反转链表

cpp 复制代码
class Solution {
public:
    ListNode* reverseList(ListNode* head) {
        ListNode* phead=new ListNode();
        if(head==nullptr) return nullptr;
        phead->next=head;
        ListNode*cur=head->next;
        head->next=nullptr;
        while(cur!=nullptr)
        {
            ListNode*temp=cur->next;
            cur->next=phead->next;
            phead->next=cur;
            cur=temp;
        }
        return phead->next;
    }
};

相关推荐
泥泞开出花朵11 分钟前
LRU缓存淘汰算法的详细介绍与具体实现
java·数据结构·后端·算法·缓存
ankleless30 分钟前
C语言(02)——标准库函数大全(持续更新)
c语言·开发语言·算法·标准库函数·零基础自学
补三补四1 小时前
Shapley与SHAP
大数据·人工智能·算法·机器学习·数据分析
KarrySmile1 小时前
Day17--二叉树--654. 最大二叉树,617. 合并二叉树,700. 二叉搜索树中的搜索,98. 验证二叉搜索树
数据结构·算法·二叉树·二叉搜索树·合并二叉树·最大二叉树·验证二叉搜索树
凤年徐1 小时前
【数据结构与算法】21.合并两个有序链表(LeetCode)
c语言·数据结构·c++·笔记·算法·链表
程序员老冯头1 小时前
第三十二节 MATLAB函数
数据结构·算法·matlab
lifallen2 小时前
hadoop.yarn 带时间的LRU 延迟删除
java·大数据·数据结构·hadoop·分布式·算法
淮北4945 小时前
STL学习(十一、常用的算数算法和集合算法)
c++·vscode·学习·算法
糖葫芦君5 小时前
玻尔兹曼分布与玻尔兹曼探索
人工智能·算法·机器学习
摸鱼仙人~5 小时前
Redis 数据结构全景解析
数据结构·数据库·redis