题解 | #BM8 链表中倒数最后k个结点#

链表中倒数最后k个结点

https://www.nowcoder.com/practice/886370fe658f41b498d40fb34ae76ff9

/**
 * struct ListNode {
 *    int val;
 *    struct ListNode *next;
 * };
 *
 * C语言声明定义全局变量请加上static,防止重复定义
 */
/**
 * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
 *
 * 
 * @param pHead ListNode类 
 * @param k int整型 
 * @return ListNode类
 */
struct ListNode* FindKthToTail(struct ListNode* pHead, int k) {
    if (pHead == NULL)
        return pHead;
    struct ListNode* kTh = pHead;
    while (k-- > 0) { // 移动到第 k 个节点
        if (kTh == NULL) return NULL;
        kTh = kTh->next;
    }
    while (kTh) { // kTh 移动到末尾时,pHead 移动到倒数第 k 个节点
        kTh = kTh->next;
        pHead = pHead->next;
    }
    return pHead;
}
全部评论

相关推荐

不愿透露姓名的神秘牛友
11-24 20:55
阿里国际 Java工程师 2.7k*16.0
程序员猪皮:没有超过3k的,不太好选。春招再看看
点赞 评论 收藏
分享
11-14 16:13
已编辑
重庆科技大学 测试工程师
Amazarashi66:不进帖子我都知道🐮❤️网什么含金量
点赞 评论 收藏
分享
评论
点赞
1
分享
牛客网
牛客企业服务