C练题笔记之:Leetcode-面试题 02.02. 返回倒数第 k 个节点

题目:

实现一种算法,找出单向链表中倒数第 k 个节点。返回该节点的值。

注意:本题相对原题稍作改动

示例:

输入: 1->2->3->4->5 和 k = 2
输出: 4
说明:

给定的 k 保证是有效的。

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/kth-node-from-end-of-list-lcci
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

解题思路:

1,获取总节点数

2,通过总结点数减去k,获得指定节点位置

结果:

C练题笔记之:Leetcode-面试题 02.02. 返回倒数第 k 个节点_第1张图片

代码:

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     struct ListNode *next;
 * };
 */


int kthToLast(struct ListNode* head, int k){
    int count = 1;
    struct ListNode *p;

    p = head->next;
    while(p)
    {
        count++;
        p = p->next;
    }
    count -= k;

    p = head;
    for(int i = 0; i < count; i++)
    {
        p = p->next;
    }
    return p->val;
}

 

你可能感兴趣的:(链表,leetcode,c语言)