算法-链表篇05-删除链表的倒数第N个结点

删除链表的倒数第N个结点

力扣题目链接

题目描述

给你一个链表,删除链表的倒数第 n 个结点,并且返回链表的头结点。

解题思路

先创建一个虚拟头结点pre,然后开始核心方法:使用两个指针来遍历链表,一个用于寻找最后一个节点p,一个用于寻找应该删除的结点cur。

先从虚拟头结点向后寻找n次,此时将cur指向pre,然后开始继续向后遍历链表。当p的next为空时,cur正好指向倒数第N+1个结点。

此时利用cur删除倒数第N个结点即可

题解

复制代码
class Solution {
public:
    ListNode* removeNthFromEnd(ListNode* head, int n) {
        ListNode* pre = new ListNode(0, head);
        ListNode* cur = pre;
        ListNode* p = pre;
        for(int i = 0; i < n; i++){
            p = p->next;
        }
        while(p->next){
            p = p->next;
            cur = cur->next;
        }
        cur->next = cur->next->next;
        head = pre->next;
        delete pre;

        return head;
    }
};

总结

这道题使用双指针法进行计数还是很简单的,如果想不到也可以先遍历一遍链表记录下长度,然后再寻找,一样很简单的。

相关推荐
mm-q29152227291 天前
【天野学院5期】 第5期易语言半内存辅助培训班,主讲游戏——手游:仙剑奇侠传4,端游:神魔大陆2
人工智能·算法·游戏
MoRanzhi12031 天前
Python 实现:从数学模型到完整控制台版《2048》游戏
数据结构·python·算法·游戏·数学建模·矩阵·2048
2401_841495641 天前
【数据结构】基于BF算法的树种病毒检测
java·数据结构·c++·python·算法·字符串·模式匹配
蒙奇D索大1 天前
【算法】递归算法实战:汉诺塔问题详解与代码实现
c语言·考研·算法·面试·改行学it
一只鱼^_1 天前
力扣第 474 场周赛
数据结构·算法·leetcode·贪心算法·逻辑回归·深度优先·启发式算法
叫我龙翔1 天前
【数据结构】从零开始认识图论 --- 单源/多源最短路算法
数据结构·算法·图论
深圳佛手1 天前
几种限流算法介绍和使用场景
网络·算法
陌路201 天前
S14排序算法--基数排序
算法·排序算法
ysa0510301 天前
虚拟位置映射(标签鸽
数据结构·c++·笔记·算法
Yue丶越1 天前
【C语言】深入理解指针(二)
c语言·开发语言·数据结构·算法·排序算法