题解 | #链表中倒数最后k个结点#
链表中倒数最后k个结点
http://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 ) {
// write code here
//空链表返回空
if(pHead==NULL)
return NULL;
int n=0;
//遍历链表,看一下结点总数
struct ListNode* node1=pHead;
while(node1){
node1=node1->next;
n++;
}
//如果倒数的数大于结点总数,那么返回空
if(k>n){
return NULL;
}
//返回倒数的结点
int m=0;
struct ListNode* node2=pHead;
while(m<n-k){
node2=node2->next;
m++;
}
return node2;
}