标签:count 结点 ListNode offer int 链表 倒数第 指针
一、题目描述
输入一个链表,输出该链表中倒数第k个结点。
二、思路
思路一:
设置两个指针,一个快指针,一个慢指针。
慢指针在第一个节点,快指针先前进k个结点。然后快慢指针一起前进,当快指针到达终点时,慢指针所指结点为倒数第k个结点。
思路二:
先遍历一遍链表,得出链表长度count。然后从头开始前进count-k次,可得倒数第k个结点。
三、代码
/* public class ListNode { int val; ListNode next = null; ListNode(int val) { this.val = val; } }*/ //思路二 public class Solution { public ListNode FindKthToTail(ListNode head,int k) { if(null==head){ return null; } int count = 0; ListNode node = head; while(node!=null){ count++; node = node.next; } if(count<k){ return null; } ListNode res = head; for(int i=0;i<count-k;i++){ res = res.next; } return res; } }
标签:count,结点,ListNode,offer,int,链表,倒数第,指针 来源: https://www.cnblogs.com/blzm742624643/p/12237706.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。