剑指offer 链表中倒数第k个结点(C++)

该博客介绍了如何在C++中找到链表中倒数第k个节点的方法,包括解题思路和代码实现。首先,需要确保链表元素总数大于k,然后找到正数第n-k+1个节点即可。代码中使用了unsigned int类型来存储节点计数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目描述

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

解题思路

1、统计链表中所有元素个数,必须要大于kkk

2、如果链表中一共有nnn个整数(n>k)(n > k)n>k),打印倒数第kkk个数,即打印正数第n−k+1n - k + 1nk+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;
    }
};
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值