博客
关于我
[LeetCode] 876.求链表的中间节点 , [剑指offer]求链表中倒数第K个节点
阅读量:61 次
发布时间:2019-02-26

本文共 1364 字,大约阅读时间需要 4 分钟。

目录:

1.求链表的中间节点

题目描述

给定一个头结点为 head 的非空单链表,返回链表的中间结点。

如果有两个中间结点,则返回第二个中间结点。

示例1

输入:[1,2,3,4,5]
输出:此列表中的结点 3
示例2
输入:[1,2,3,4,5,6]
输出:此列表中的结点 4
使用语言: C语言

思路解析:

此题可以使用快慢指针解,给定两个指针指一个快指针fast,一个慢指针slow,使两个指针向分别指向head位置,因为求中间节点所以,快指针一次走两个位置,慢指针一次走一个位置(即快指针走的是慢指针的二倍),所以当快指针走到尾时慢指针刚好走到中间位置,需要注意的是整个循环结束的条件

图解如下:

链表中节点数为奇数,快指针每次走量个位置,在fast->next == NULL 时结束
在这里插入图片描述
链表中节点数为偶数,快指针每次走量个位置,在fast == NULL 时结束
在这里插入图片描述

代码实现:

struct ListNode* middleNode(struct ListNode* head){      //定义快慢两个指针,到head位置    struct ListNode* fast = head;    struct ListNode* slow = head;    while(fast && fast->next)    {           //慢指针一次走一个位置        slow = slow->next;        //快指针一次走两个位置        fast = fast->next->next;    }    return slow;}

2.求链表中倒数第K个节点

题目描述

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

示例1

输入:3,{1,2,3,4,5,6,7}
输出:{5}

使用语言: C语言

思路解析:

此题思路和求链表的中间节点的思路类似,求链表中的倒数第K个节点,即给定两个指针指一个快指针fast,一个慢指针slow,使两个指针位置相差K,在让两个指针同时走,当快指针走到尾 fast = NULL 时,慢指针的位置就是倒数第K个节点的位置:注意需要将极端情况考虑进去,当倒数第K个数不存在的情况 (5,{1,2,3})

图解如下:

在这里插入图片描述

代码实现:

struct ListNode* FindKthToTail(struct ListNode* pListHead, int k ){      struct ListNode* fast = pListHead;   struct ListNode* slow = pListHead;    //先让两个指针相隔K个节点    for(int i = 0;i < k;++i)    {           //即不存在倒数第K个数的情况        if(fast == NULL)        return NULL;        fast = fast->next;    }    //让两个指针开始同时走    while(fast)    {           slow = slow->next;        fast = fast->next;    }    return slow;}

转载地址:http://bjbz.baihongyu.com/

你可能感兴趣的文章
nginx启动脚本
查看>>
Nginx和Tomcat的区别
查看>>
Nginx在Windows上和Linux上(Docker启动)分别配置基本身份认证示例
查看>>
Nginx在Windows下载安装启动与配置前后端请求代理
查看>>
Nginx在开发中常用的基础命令
查看>>
Nginx基础知识点与使用场景梳理
查看>>
Nginx多域名,多证书,多服务配置,实用版
查看>>
nginx如何实现图片防盗链
查看>>
Nginx学习总结(10)——Nginx前后端分离将多个请求转发到多个Tomcat,负载均衡反向代理
查看>>
Nginx学习总结(11)——提高Nginx服务器的安全性,稳定性和性能的12种技巧
查看>>
Nginx学习总结(12)——Nginx各项配置总结
查看>>
Nginx学习总结(13)——Nginx 重要知识点回顾
查看>>
Nginx学习总结(14)——Nginx配置参数详细说明与整理
查看>>
Nginx学习总结(15)—— 提升 Web 应用性能的十个步骤
查看>>
Nginx学习总结(1)——Nginx入门简介
查看>>
Nginx学习总结(3)——Nginx配置及应用场景之高级配置
查看>>
Nginx学习总结(4)——负载均衡session会话保持方法
查看>>
Nginx学习总结(7)——Nginx配置HTTPS 服务器
查看>>
Nginx学习总结(8)——Nginx服务器详解
查看>>
Nginx学习总结(9)——前端跨域问题解决
查看>>