算法-获取链表中倒数第k个结点
2017-07-31 23:27
330 查看
题目:
输入一个链表,输出该链表中的倒数第k个结点。比如链表中的值为1,2,3,4,5,6。倒数第三个结点为值为4的结点。链表定义如下:
解题思路:
这个问题相对来说还是挺好理解的,要找到倒数第k个结点,最直接的思路肯定是倒着数k个结点不就好了,但是问题是链表不能从尾结点开始遍历,只能从头结点开始。
那么倒数第k个的问题基于必须要转化成正数第n-k+1个,其中n是整个链表的长度,那么问题就可以这样解决:
(1)先遍历一遍链表,得到链表的长度n;
(2)再从头遍历链表,遍历到n-k+1个就是要找到的倒数第k个结点。
但是这种方法必须要遍历两次,那么有没有遍历一次就得到正确结果的方法呢?
可以通过定义两个指针,第一个指针p1先走k-1步后第二个指针p2再开始走,到k步时两个指针同步走,那么当p1到底链表的结尾时,p2正好走到了第k个结点。
此时这种方法牺牲了空间复杂度(两个指针),换来了时间复杂度的降低,这也是设计算法时比较常用的方式—“用空间换时间”。
代码实现:
上述代码具有较好的鲁棒性:
(1)如何输入的 *pListHead 为空,程序返回null而不会异常。
(2)如果输入链表 *pListHead长度小于k个,程序返回null而不会异常。(一个小于k个长度的链表显然没有倒数第k个结点)
(3)如果输入的k=0,代码不会异常,而是返回null。
输入一个链表,输出该链表中的倒数第k个结点。比如链表中的值为1,2,3,4,5,6。倒数第三个结点为值为4的结点。链表定义如下:
struct ListNode { int value; ListNode *next; };
解题思路:
这个问题相对来说还是挺好理解的,要找到倒数第k个结点,最直接的思路肯定是倒着数k个结点不就好了,但是问题是链表不能从尾结点开始遍历,只能从头结点开始。
那么倒数第k个的问题基于必须要转化成正数第n-k+1个,其中n是整个链表的长度,那么问题就可以这样解决:
(1)先遍历一遍链表,得到链表的长度n;
(2)再从头遍历链表,遍历到n-k+1个就是要找到的倒数第k个结点。
但是这种方法必须要遍历两次,那么有没有遍历一次就得到正确结果的方法呢?
可以通过定义两个指针,第一个指针p1先走k-1步后第二个指针p2再开始走,到k步时两个指针同步走,那么当p1到底链表的结尾时,p2正好走到了第k个结点。
此时这种方法牺牲了空间复杂度(两个指针),换来了时间复杂度的降低,这也是设计算法时比较常用的方式—“用空间换时间”。
代码实现:
ListNode* FindKthToTail(ListNode* pListHead, unsigned int k) { if(pListHead == NULL || k == 0) return NULL; ListNode *pAhead = pListHead; ListNode *pBehind = NULL; for(unsigned int i = 0; i < k - 1; ++ i) { if(pAhead->next != NULL) pAhead = pAhead->next; else { return NULL; } } pBehind = pListHead; while(pAhead->next != NULL) { pAhead = pAhead->next; pBehind = pBehind->next; } return pBehind; }
上述代码具有较好的鲁棒性:
(1)如何输入的 *pListHead 为空,程序返回null而不会异常。
(2)如果输入链表 *pListHead长度小于k个,程序返回null而不会异常。(一个小于k个长度的链表显然没有倒数第k个结点)
(3)如果输入的k=0,代码不会异常,而是返回null。
相关文章推荐
- 每天学习一算法系列(13) (输入一个单向链表,输出该链表中倒数第k个结点)
- 获取链表中倒数第k个结点
- 算法题9 查找链表中倒数第k个结点
- 每天一道算法题7 查找链表中倒数第k个结点 ; 输入一个单向链表。如果该链表的结点数为奇数,输出中间的结点;如果链表结点数为偶数,输出中间两个结点前面的一个
- 每天一个小算法(5)----找到链表倒数第K个结点
- [算法]在单链表和双链表中删除倒数第k个结点
- 每天一个算法之链表中倒数第K个结点
- 算法题:求链表倒数第K个结点
- 【经典算法】: 求链表中倒数第K个结点
- 剑指offer-算法题练习:part16 链表中倒数第k个结点
- 数据结构——算法之(004)(输入一个单向链表,输出该链表中倒数第k个结点)
- 算法学习五---输出链表中倒数第k个结点
- 每天一道算法题7 查找链表中倒数第k个结点
- 每天一道算法题——链表中倒数第k个结点
- 面试算法(十四)链表中倒数第k个结点
- 重拾算法之剑指Offier——链表中倒数第k个结点
- 微软算法100道题------输入一个单向链表,输出该链表中倒数第k个结点。链表的倒数第0个结点为链表的尾指针
- 算法题目---链表中倒数第k个结点
- 【算法】求链表中倒数第K个结点
- 华为oj 输出单向链表中倒数第k个结点