快慢指针问题
思路:定义两个指针,一个快指针(fastp),一个慢指针(slowp),在单链表中,让快慢指针同时从同一位置,向后遍历,他们每次的步数都固定,比如慢指针每次向后移动1步,快指针移动2步,当快指针到达最后时,慢指针就是中间位置,主要是明白他们的每一步的差是恒定的,所以两个指针的路程也是成比例的。
//我的解答
class Solution {
public ListNode middleNode(ListNode head) {
if(head == null){
return head;
}
ListNode p = head;
ListNode p2 = head;
while(p2 != null && p2.next != null){
p = p.next;
p2 = p2.next.next;
}
return p;
}
}
标签:p2,快慢,head,ListNode,next,指针
From: https://www.cnblogs.com/zh-Note/p/17135147.html