【经验总结】LeetCode中链表类题目经验总结十条

本文介绍了链表的基本概念、技巧和常见问题解决方法,如移动链表、查找环、倒数节点等,并推荐了力扣LeetCode上的12个代表性链表题目,适合进阶学习者巩固和提升链表算法能力。


在这里插入图片描述

前言

链表是以节点(node)存储的链式存储结构,一个node包含一个data域(存放数据)和一个next域(存放下一个node的指针),链表的各个节点不一定是连续的,它可以分为带头结点和不带头结点。头结点仅包含next域。
在这篇文章中,主要讲解使用链表的小技巧,如何使用这些技巧来解题,并且列举LeetCode中具有代表性的链表题目,这篇文章非常适合已经刷过一定数量链表类题目的uu观看,看完有助于巩固总结做链表这类题目的经验技巧。

干货经验汇总

第一梯队

1、 函数中需要移动链表时,最好新建一个指针来移动,以免更改原始指针位置。

2、 单链表有带头节点不带头结点的链表之分,一般做题默认头结点是有值的

3、 链表的内存时不连续的,一个节点占一块内存,每块内存中有一块位置(next)存放下一节点的地址。

3、 链表中找的思想:快慢指针,创建两个指针,一个快指针:一次走两步一个慢指针:一次走一步,若相遇则有环,若指向null则无环。

4、 链表找倒数第k个节点思想:创建两个指针,第一个指针查询链表中结点的个数count,然后count-k确定删除结点的位置,用第二个指针遍历链表到count-n-1个位置。

5、 反向链表思想:从前往后将每个节点的指针反向,即next内的地址

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值