描述
给定一个单链表的头结点pHead(该头节点是有值的,比如在下图,它的val是1),长度为n,反转该链表后,返回新链表的表头。
如当输入链表{1,2,3}时,
经反转后,原链表变为{3,2,1},所以对应的输出为{3,2,1}。
以上转换过程如下图所示:
示例
输入:
{1,2,3}
返回值:
{3,2,1}
代码演示(java)👇👇
/*
public class ListNode {
int val;
ListNode next = null;
ListNode(int val) {
this.val = val;
}
}*/
public class Solution {
public ListNode ReverseList(ListNode head) {
//pre指针:用来指向反转后的节点,初始化null
ListNode pre =null;
//当前节点指针
ListNode cur=head;
//循环迭代
while(cur!=null){
//cur_next节点,永远指向当前节点cur的下一个节点
ListNode Cur_next=cur.next;
//反转的关键:当前的节点指向其前一个节点(注意着不是双向链表,没有前驱指针)
cur.next=pre;
//更新pre
pre=cur;
//更新当前
cur=Cur_next;
}
//为什么返回pre?因为pre是反转之后的头节点
return pre;
}
}
总结🐱🚀🐱🚀
每日一练,坚持🤪🤪