力扣19删除链表的倒数第N个结点(C++)

题目


知识点

双指针------快慢指针

创建链表节点


思路

双指针思想,一个快指针先向前走n步,然后两个指针一起移动


题解

cpp 复制代码
class Solution {
public:
    ListNode* removeNthFromEnd(ListNode* head, int n) {
        //创建虚拟头节点,值为0,next指向原链表头
        ListNode* dummyHead = new ListNode(0);
        dummyHead->next = head;
        //可以写成ListNode* dummyHead = new ListNode(0,head);struct里面定义了这种形式

        ListNode* slow = dummyHead;
        ListNode* fast = dummyHead;
        while (n-- && fast != NULL) {
            fast = fast->next;
        }

        fast = fast->next; // fast再提前走一步,因为需要让slow指向删除节点的上一个节点
        while (fast != NULL) {
            fast = fast->next;
            slow = slow->next;
        }
        slow->next = slow->next->next;

        // ListNode *tmp = slow->next;  C++释放内存的逻辑
        // slow->next = tmp->next;
        // delete tmp;

        return dummyHead->next;
    }
};
相关推荐
孞㐑¥2 小时前
算法—记忆化搜索
开发语言·c++·经验分享·笔记·算法
二进制星轨2 小时前
leecode-70-颜色分类-算法题解
数据结构·算法·排序算法
xushichao19892 小时前
代码覆盖率工具实战
开发语言·c++·算法
2401_857918292 小时前
C++与WebAssembly集成
开发语言·c++·算法
2401_879693872 小时前
C++与微服务架构
开发语言·c++·算法
华科大胡子3 小时前
开源项目Git贡献
c++
比昨天多敲两行3 小时前
C++ 继承
开发语言·c++·面试
2501_908329853 小时前
C++中的装饰器模式实战
开发语言·c++·算法
程序猿编码3 小时前
Linux 进程注入:从调试器到武器化的技术演进
linux·运维·服务器·c++·进程注入