题目描述

输入一个链表,输出该链表中倒数第k个结点。
C++实现:
先计算链表中有多少个结点,总数记为count
那么倒数第k个结点即顺数第count-k+1个结点
/*
struct ListNode {
    int val;
    struct ListNode *next;
    ListNode(int x) :
            val(x), next(NULL) {
    }
};*/
class Solution {
public:
    ListNode* FindKthToTail(ListNode* pListHead, unsigned int k) {
        ListNode * p = pListHead;
        int count = 0;
        while(p){
            count++;
            p = p->next;
        }
        ListNode * q = {};
        if(k>count) return q;
        else{
            q = pListHead;
            int i = 1;
            while(i){
                if(i == count-k+1){
                    return q;
                }
                q = q->next;
                i++;
            }
        }
        
    }
};

剑指offer(十四):链表中倒数第k个结点

缺点:需要遍历两次链表

 讨论里面其他人的思想:

//p指针先跑,并且记录节点数,当p指针跑了k-1个节点后,pre指针开始跑,
//当p指针跑到最后时,pre所指指针就是倒数第k个节点
用java语言实现该思想:
public class Solution {
    public ListNode FindKthToTail(ListNode head,int k) {
        ListNode p = head;
        ListNode q = head;

        int count = 0;
        while(p!=null){
            count++;
            if(count > k)
                q = q.next;
            p = p.next;
        }
        return count>=k?q:null;
    }
}
剑指offer(十四):链表中倒数第k个结点

 

 

相关文章:

  • 2022-12-23
  • 2021-04-23
  • 2021-12-12
  • 2021-08-13
  • 2021-05-26
  • 2021-06-30
  • 2021-11-24
  • 2022-12-23
猜你喜欢
  • 2022-02-21
  • 2021-05-02
  • 2021-10-31
  • 2022-02-08
  • 2021-07-23
相关资源
相似解决方案