每日一练(剑指offer)反转链表

时间:2021-09-19 00:52:00

描述

给定一个单链表的头结点pHead(该头节点是有值的,比如在下图,它的val是1),长度为n,反转该链表后,返回新链表的表头。

如当输入链表{1,2,3}时,

经反转后,原链表变为{3,2,1},所以对应的输出为{3,2,1}。

以上转换过程如下图所示:

每日一练(剑指offer)反转链表

示例

输入:

{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;
}
}

总结????‍????????‍????

每日一练,坚持????????