题目描述
输入一个链表,输出该链表中倒数第k个结点。
解题思路
1、统计链表中所有元素个数,必须要大于kkk。
2、如果链表中一共有nnn个整数(n>k)(n > k)(n>k),打印倒数第kkk个数,即打印正数第n−k+1n - k + 1n−k+1个数。
代码实现
unsigned int 类型为无符号整型,是指用该变量定义的整数只能是正数,int类型则是signed int 类型的默认写法,通常,无符号类型变量要比符号类型变量多一位。16位的unsigned int 范围为0~65535,int类型的变量范围为-32768~32767
/*
struct ListNode {
int val;
struct ListNode *next;
ListNode(int x) :
val(x), next(NULL) {
}
};*/
class Solution {
public:
ListNode* FindKthToTail(ListNode* pListHead, unsigned int k) {
if(pListHead == NULL)
return NULL;
ListNode* tmp = pListHead;
int n = 0;
for(;tmp;tmp = tmp->next)
n++;
if(n < k)
return NULL;
int count = 0;
for(tmp = pListHead; tmp, count < n - k; tmp = tmp->next, count++);
return tmp;
}
};