(反转链表)题目描述:
输入一个链表,反转链表后,输出新链表的表头。
解题思路:题给的链表是一个单向链表,所以为了反转整个链表,需要将节点之间的指向问题进行整理,最后一个结点指向倒数第二个,倒数第二个指向倒数第三个,......,第二个指向第一个,第一个指向null;这就需要把结点挨个从链表上摘下来,做调整;这个调整过程需要两个指针辅助:pre记录其前一个结点位置,好让该结点的next指针指向前一个结点,但是在指向前一个结点前需要用一个指针p记录后一个结点地址,避免结点丢失。
- 以head结点为例步骤如下:
- 1.反转后head是指向null,所以未反转的时候其前一个结点应该是null,初始化pre指针为null;
- 2.用p指针记录head的下一个结点head.next;
- 3.从链表上摘下head,即让head.next指向pre;
- 4.此时已完成head结点的摘取及与前一个节点的连接,则我们需要操作下一个结点:故需移动pre和head,让pre指向head,head指向下一个节点。
- 重复这四个操作直到head走完原链表,指向null时,循环结束,返回pre。
/* public class ListNode { int val; ListNode next = null; ListNode(int val) { this.val = val; } }*/ public class Solution { public ListNode ReverseList(ListNode head) { //判断为空的链表和长度为1的链表 if(head == null||head.next == null){ return head; } //初始化两个指针用于保存当前的节点前后位置 ListNode pre = null; ListNode nx = null; while(head != null){ //先保存当前节点的下一节点的位置 nx = head.next; //完成反转(让head.next指向pre) head.next = pre; //移动上一节点指针 pre = head; //移动当前节点,上面第一步就保存了下一节点的位置的 head = nx; } return pre; } }
来源:https://www.cnblogs.com/dashenaichicha/p/12572366.html