LeetCode 19.删除链表的倒数第N个结点 C写法

LeetCode 19.删除链表的倒数第N个结点 C写法

思路🤔:

我们先创建一个哨兵位,这样便于我们头删,然后利用双指针 ,一个指针先走n+1步 (带哨兵位要多走一步),然后两个指针再一起走,当先走的指针结束,那么后走的指针下一个就是我们要删除的结点,最后用新的头结点接收即可。

代码🔎:

c 复制代码
struct ListNode* removeNthFromEnd(struct ListNode* head, int n) {
        struct ListNode* guard = (struct ListNode*)malloc(sizeof(struct ListNode)); //创建哨兵位
        guard->next = head;
        struct ListNode* fast = guard;
        struct ListNode* slow = guard;

        while(n >= 0) //先走n+1步
        {
            fast = fast->next;
            n--;
        }

        while(fast != NULL) //fast走到空就结束,此时slow刚好在删除的前一个
        {
            slow = slow->next;
            fast = fast->next;
        }

        struct ListNode* del = slow->next;
        slow->next = slow->next->next;  //更新结点
        free(del);
        struct ListNode* newhead = guard->next; //创建新头
        free(guard);
        return newhead;
}
相关推荐
dddddppppp1236 分钟前
c 模拟一个fat16文件系统
c语言·c++·算法
小刘爱玩单片机1 小时前
【stm32简单外设篇】- 三色LED
c语言·stm32·单片机·嵌入式硬件
hope_wisdom1 小时前
C/C++数据结构之队列基础
c语言·数据结构·c++·队列·queue
会员果汁2 小时前
算法-拓扑排序-C
c语言·开发语言·算法
YGGP2 小时前
【Golang】LeetCode 72. 编辑距离
算法·leetcode
Dillon Dong2 小时前
从C到Simulink:什么是MATLAB_MEX_FILE 宏,如何阻挡STM32 HAL 头文件
c语言·stm32·matlab
YGGP2 小时前
【Golang】LeetCode 62. 不同路径
算法·leetcode
会员果汁3 小时前
算法-并查集-C
c语言·开发语言·算法
努力学算法的蒟蒻3 小时前
day47(12.28)——leetcode面试经典150
算法·leetcode·面试
脏脏a4 小时前
链式存储范式下的二叉树:基础操作实现解析
c语言·数据结构·算法·二叉树