【剑指offer】链表中倒数第k个节点

题目描述

输入一个链表,输出该链表中倒数第k个结点。

思路

方法有很多,可以用一个栈来存链表中的所有节点,然后输出栈中的第k个节点就可以了;也可以用快慢指针,快指针先走k-1步之后慢指针再走,当快指针走到头时,慢指针所在的节点即倒数第k个结点;下面代码是入栈的方法。另外要判断k不合法的情况。

代码

/*
struct ListNode {
	int val;
	struct ListNode *next;
	ListNode(int x) :
			val(x), next(NULL) {
	}
};*/
class Solution {
public:
    ListNode* FindKthToTail(ListNode* pListHead, unsigned int k) {
        int count = 0;
        stack<ListNode*> s;
        while(pListHead){
            s.push(pListHead);
            pListHead = pListHead->next;
            count++;
        }
        if(k == 0 || k > count){
            return NULL;
        }
        ListNode* t;
        while(k--){
            t = s.top();
            s.pop();
        }
        return t;
    }
};

 

全部评论

相关推荐

拒绝无效加班的小师弟很中意你:求职意向没有,年龄、课程冗余信息可以删掉,需要提升项目经历。排版需要修改。
点赞 评论 收藏
分享
11-15 18:39
已编辑
西安交通大学 Java
全村最靓的仔仔:卧槽,佬啥bg呢,本也是西交么
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务