剑指offer----C语言版----第十六天----面试题22:链表中的倒数第k个节点
创始人
2024-05-10 13:37:50
0

目录

1. 链表中倒数第 k 个节点 

1.1 题目描述

1.2 思路一

 1.3 思路二:

 1.4 总结----代码的鲁棒性


1. 链表中倒数第 k 个节点 

原题链接:

剑指 Offer 22. 链表中倒数第k个节点 - 力扣(LeetCode)icon-default.png?t=MBR7https://leetcode.cn/problems/lian-biao-zhong-dao-shu-di-kge-jie-dian-lcof/

1.1 题目描述

输入一个链表,输出该链表中倒数第k个节点。为了符合大多数人的习惯,本题从1开始计数,即链表的尾节点是倒数第1个节点。

例如,一个链表有 6 个节点,从头节点开始,它们的值依次是 1、2、3、4、5、6。这个链表的倒数第 3 个节点是值为 4 的节点。

1.2 思路一

题目求的是链表的倒数第 k 个节点,根据题目得知这是一个单向链表,我们无法从后往前找到链表的倒数第 k 个节点,于是我们会想到从前往后去找倒数第 k 个节点。但是我们不知道倒数第 k 个节点前面有多少个节点。于是,我们很自然地想到先求出链表的节点个数 count,然后就求出了倒数第 k 个节点前有 count - k 个节点,然后我们再用一个指针去遍历找到倒数第 k 个节点就可以啦。

 

struct ListNode* getKthFromEnd(struct ListNode* head, int k) {//对输入进行判断,提高代码的鲁棒性(健壮性)if (head == NULL || k <= 0){return NULL;}//用cur指针遍历链表统计节点个数struct ListNode* cur = head;int count = 0;while (cur != NULL){count++;cur = cur->next;}//对输入进行判断,提高代码的鲁棒性    if (k > count){return NULL;}//找到倒数第k个节点struct ListNode* ret = head;int i;for (i = 1; i < count - k + 1; i++){ret = ret->next;}return ret;
}

 1.3 思路二:

遍历两次链表还是太麻烦了,能不能只遍历一次链表就找到结果呢?答案是肯定的,我们可以维护两个指针slow,fast,将他们均初始化为头结点 head。然后让 slow 指针先不动,让 fast 指针先向后走k-1步,此时slow与fast之间就隔了 k - 1 个节点,然后保持slow与fast之间的距离始终为 k - 1个节点,即之后让 slow 与 fast 同时向后移动。直到 fast 指向尾节点,此时 slow 就指向了链表的倒数第 k 个节点。

下面以链表 1->2->3->4->5->NULL ,k = 3,举例分析:

 

 

struct ListNode* getKthFromEnd(struct ListNode* head, int k){//对输入进行判断,提高代码的鲁棒性(健壮性)if(head == NULL && k <= 0){return NULL;}//两个指针的初始化struct ListNode* slow = head, *fast = head;//快指针先走走k-1步,此情况中可能超过快指针可走的步数,//此时表明链表的节点个数小于k的值,返回NULLint i = 0;for(i = 0;i < k - 1;i++){if(fast != NULL)fast = fast->next;elsereturn NULL;}//让慢指针与快指针同时走,直到快指针走到尾节点//最后慢指针指向的节点就是倒数第k个节点while(fast->next != NULL){slow = slow->next;fast = fast->next;}return slow;
}

 1.4 总结----代码的鲁棒性

鲁棒性是英文Robust的英译,有时也翻译成健壮性。所谓的鲁棒性是值程序能够判断输入是否合乎规范要求,并对不符合要求的输入予以合理的处理。

对于本题而言对于鲁棒性应做如下考虑:

(1):输入的head指针为空指针的情况。

(2):链表的节点数小于k的值。

(3):k为非正数的情况。

相关内容

热门资讯

时空猎人安卓苹果系统,探索无尽... 你知道吗?最近在手机游戏圈里,有一款叫做《时空猎人》的游戏可是火得一塌糊涂呢!不管是安卓用户还是苹果...
安卓9.0系统的电视,新一代电... 亲爱的读者们,你是否也像我一样,对科技新玩意儿充满好奇?今天,我要和你聊聊一个让人眼前一亮的话题——...
小pc安装安卓系统,轻松安装安... 你有没有想过,你的小PC也能变身成为安卓系统的超级玩家呢?没错,就是那个平时默默无闻的小家伙,现在也...
高通备份安卓系统,全方位数据安... 你知道吗?在这个科技飞速发展的时代,手机备份可是个不得不提的话题。尤其是对于安卓用户来说,选择一个靠...
谷歌安卓系统有多少,从诞生到全... 你有没有想过,那个无处不在的谷歌安卓系统,究竟在全球有多少用户呢?它就像一个神秘的数字,每天都在悄悄...
fc黄金传说安卓系统,畅享复古... 你有没有听说最近安卓系统上的一款超酷的游戏——《FC黄金传说》?这款游戏可是让不少玩家都沉迷其中,今...
变小的我安卓系统,安卓系统演变... 你有没有发现,最近你的手机好像变轻了?没错,说的就是你,那个陪伴你多年的安卓系统。它悄无声息地进行了...
vivo安卓系统小彩蛋,体验科... 你知道吗?在vivo的安卓系统中,竟然隐藏着一些超有趣的小彩蛋!这些小彩蛋就像是在手机里埋下的宝藏,...
安卓系统如何强制重启,安卓系统... 手机突然卡壳了,是不是又该给它来个“大保健”了?没错,今天就来聊聊安卓系统如何强制重启。别小看这个看...
全民飞行团安卓系统,体验指尖上... 你知道吗?最近在手机游戏圈里,有个叫做“全民飞行团”的新星正在闪耀!这款游戏不仅吸引了无数玩家的目光...
安卓鸿蒙系统壁纸软件,壁纸软件... 亲爱的手机控们,你是否厌倦了单调的壁纸?想要给你的安卓手机换上充满科技感的鸿蒙系统风格壁纸?那就跟我...
安卓系统ram重新分区,提升系... 你有没有发现,你的安卓手机最近有点儿卡呢?别急,别急,今天就来给你揭秘如何给安卓系统的RAM来个重新...
迷你退出安卓系统了吗,转型新篇... 最近有没有发现你的手机上那个可爱的迷你退出图标突然不见了?别急,让我来给你揭秘迷你退出安卓系统了吗的...
华为优先使用安卓系统,打造自主... 你知道吗?最近科技圈里有个大动作,那就是华为宣布优先使用安卓系统。这可不是一个简单的决定,它背后可是...
安卓系统隐藏了设置,隐藏设置功... 你知道吗?安卓系统这个大宝藏里,竟然隐藏着一些不为人知的设置!是不是听起来就有点小激动呢?别急,今天...
反渣恋爱系统安卓,收获真爱 你有没有听说过那个神奇的“反渣恋爱系统安卓”呢?最近,这款应用在网络上可是火得一塌糊涂,不少单身狗都...
安卓出厂系统能升级,探索无限可... 你知道吗?现在这个时代,手机更新换代的速度简直就像坐上了火箭!而说到手机,安卓系统可是占据了半壁江山...
老安卓刷机系统,从入门到精通 你有没有想过,你的老安卓手机其实还有大大的潜力呢?没错,就是那个陪伴你多年的老安卓,它可不是只能用来...
安卓粉ios系统app,兼容性... 你有没有发现,身边的朋友圈里,安卓粉和iOS系统粉总是争论不休?今天,咱们就来聊聊这个话题,看看安卓...
安卓系统语言下载,探索安卓系统... 你有没有想过,你的安卓手机是不是该换换口味了?没错,就是语言!想象如果你能轻松切换到自己喜欢的语言,...