本文共 716 字,大约阅读时间需要 2 分钟。
给定一个带有头结点 head 的非空单链表,返回链表的中间结点。
如果有两个中间结点,则返回第二个中间结点。
示例 1:输入:[1,2,3,4,5]输出:此列表中的结点 3 (序列化形式:[3,4,5])返回的结点值为 3 。 (测评系统对该结点序列化表述是 [3,4,5])。注意,我们返回了一个 ListNode 类型的对象 ans,这样:ans.val = 3, ans.next.val = 4, ans.next.next.val = 5, 以及 ans.next.next.next = NULL.示例 2:输入:[1,2,3,4,5,6]输出:此列表中的结点 4 (序列化形式:[4,5,6])由于该列表有两个中间结点,值分别为 3 和 4,我们返回第二个结点。
解题思路:
根据题意发现无论链表的长度是奇数还是偶数,中间结点的位置都是需要cur(cur从头节点开始)向后走二分之一的链表长度步class Solution { public ListNode middleNode(ListNode head) { //如果是空链表 if(head==null){ return null; } //如果只有一个元素 if(head.next==null){ return head; } ListNode cur=head; int steps=getSize(head)/2; for(int i=0;i
转载地址:http://iflzi.baihongyu.com/