题解 | #删除链表的倒数第n个节点#

删除链表的倒数第n个节点

https://www.nowcoder.com/practice/f95dcdafbde44b22a6d741baf71653f6

struct ListNode* removeNthFromEnd(struct ListNode* head, int n ) {
    struct ListNode* h = (struct ListNode*)malloc(sizeof(struct ListNode));
    h->next = head;
    head = h;
    struct ListNode* fast = head;
    struct ListNode* slow = head;
    while(n--)
    {
        if(fast == NULL)
            return NULL;
        fast = fast->next;
    }
    while(fast->next)
    {
        fast = fast->next;
        slow = slow->next;
    }
    slow->next = slow->next->next;
    struct ListNode* ret = h->next;
    free(h);
    return ret;
}

全部评论

相关推荐

01-30 22:03
门头沟学院 Java
用微笑面对困难:我滴妈,【俩月】【实习】【主管】仨debuff吃满了,独立设计开发的项目写了绝大占比的运营板块,你独立开发,那维护、问题复盘、日志更新、bug、策划书全是自己整的? 不建议写那么大,可以从小出发更容易
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务