加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

【数据结构】单链表—链表中倒数第K个结点 — 快慢指针

发布时间:2020-12-15 05:57:50 所属栏目:安全 来源:网络整理
导读:输入一个链表,输出该链表中倒数第K个结点。注:链表的尾结点是倒数第一个结点。 思路一: 遍历一遍链表,求出链表的长度。 正数 = 长度 - 倒数 + 1 如图所示: 然后遍历正数的次数,便得到了倒数第K个结点。但是这种方法需要遍历链表两次。 思路二: 遍历一

输入一个链表,输出该链表中倒数第K个结点。注:链表的尾结点是倒数第一个结点。
思路一:
遍历一遍链表,求出链表的长度。
正数 = 长度 - 倒数 + 1
如图所示:

然后遍历正数的次数,便得到了倒数第K个结点。但是这种方法需要遍历链表两次。

思路二:
遍历一次可以用快慢指针解法,即定义两个指针,快指针和慢指针,求倒数第K个:结点快指针先走K-1步,然后快慢指针一起走当快指针走到结尾,慢指针所指向的就是所求结点。

代码如下:

template<class T>
struct ListNode
{
    T _value;
    ListNode<T>* _next;

    ListNode(const T& value)
        :_value(value),_next(NULL)
    {}
};

template<class T>
class List
{
public:
    List()
        :_head(NULL)
    {}
    bool PushBack();
   ListNode<T>* FindLastKNode(int K)//寻找链表中倒数第K个节点,快慢指针,快指针先走K-1步,然后一起走直到快指针走到结尾慢指针指向的便是倒数第K个节点
    {
        int len = Length();
        if(K<=0 || K>len)
        {
            cout<<"输入无效,重新输入"<<endl;
            return NULL;
        }
        ListNode<T>* fast = _head;
        ListNode<T>* slow = _head;

        while(fast!=NULL && K--)
        {
            fast = fast->_next;
        }
        while(fast != NULL)//如果条件是fast->_next!=NULL则最后一个节点便是倒数第0个。。。。
        {
            slow = slow->_next;
            fast = fast->_next;
        }
        return slow;
    }


private:
    ListNode<T>* _head;
};

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读