[力扣 Hot100]Day29 删除链表的倒数第 N 个结点

题目描述

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

出处

思路

两个指针间隔n,一趟遍历解决。

代码

cpp 复制代码
class Solution {
public:
    ListNode* removeNthFromEnd(ListNode* head, int n) {
        ListNode* p=head;
        ListNode* q=head;
        while(n>0){
            q=q->next;
            n--;
        }
        if(!q){
            q=p->next;
            delete(p);
            return q;
        }
        q=q->next;
        while(q){
            p=p->next;
            q=q->next;
        }
        q=p->next;
        p->next=q->next;
        delete(q);
        return head;
    }
};
相关推荐
星爷AG I8 分钟前
14-4 运动控制理论:协同理论(AGI基础理论)
算法·机器学习·agi
I_LPL27 分钟前
day48 代码随想录算法训练营 图论专题1
java·算法·深度优先·图论·广度优先·求职面试
absunique34 分钟前
多路归并算法在外部排序中的实现与优化的技术7
算法
鹿鸣悠悠41 分钟前
【AI-08】Prompt(提示词)
人工智能·算法
数据中穿行42 分钟前
12种经典排序算法完整C++实现
算法
2501_926978331 小时前
从“数字果蝇” 到“数字意识”以及AGI的构建思路
大数据·人工智能·经验分享·算法·ai写作·agi
无尽的罚坐人生1 小时前
hot 100 101. 对称二叉树
数据结构·算法·leetcode
一叶落4381 小时前
【LeetCode】1. 两数之和(Two Sum)— 哈希表经典题解(C语言)
数据结构·c++·算法·leetcode
我头发还没掉光~1 小时前
P1027 [NOIP 2001 提高组] Car 的旅行路线
c++·算法
adore.9682 小时前
3.09 复试学习
c++·学习·算法