24 反转链表
描述
给定一个单链表的头结点pHead(该头节点是有值的,比如在下图,它的val是1),长度为n,反转该链表后,返回新链表的表头。
节点 `<-` 上一个节点 当前节点 -> 下一个节点 -> 节点
需要 3 个指针,一个指向当前节点,一个指向上一个节点,一个指向下一个节点。因为反转过程中,当前节点需要将指针从下一个节点指向上一个节点,需要保存上一个节点的信息,同时当前节点变更后,需要跳到下一个节点进行操作,因此需要一个指针保存下一个节点。
/*
public class ListNode {
int val;
ListNode next = null;
ListNode(int val) {
this.val = val;
}
}*/
public class Solution {
public ListNode ReverseList(ListNode head) {
ListNode cur=head, next, pre=null;
while(cur != null){
next = cur.next;
cur.next = pre;
pre = cur;
cur = next;
}
return pre;
}
}