题解 | #链表中倒数第k个结点#

链表中倒数第k个结点

https://www.nowcoder.com/practice/529d3ae5a407492994ad2a246518148a

/**
 * struct ListNode {
 *	int val;
 *	struct ListNode *next;
 * };
 */

/**
 * 
 * @param pListHead ListNode类 
 * @param k int整型 
 * @return ListNode类
 */
struct ListNode* FindKthToTail(struct ListNode* pListHead, int k) {
	// write code here
	int number = 0;//记录链表节点个数
	struct ListNode* cur = pListHead;
	while (cur)
	{
		number++;
		cur = cur->next;
	}
	if (k >= 0 && k <= number)//此处防止输入的k是负数或者超过number,不满足则走else返回NULL
	{
		int i = 0;
		struct ListNode* ret = pListHead;
		for (i = 0; i < number - k; i++)//倒数第k个节点我们只需要从头节点往后找number-k次即可
		{
			ret = ret->next;
		}
		return ret;
	}
	else
	{
		return NULL;
	}
}

#链表#
全部评论

相关推荐

11-13 20:16
已编辑
厦门理工学院 软件测试
专业嗎喽:硕佬,把学校背景放后面几段,学校背景双非还学院,让人看了就不想往下看。 把实习经历和个人奖项放前面,用数字化简述自己实习的成果和掌握的技能,比如负责项目一次通过率90%,曾4次发现项目潜在问题风险为公司减少损失等等
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务