(反转链表)题目描述:
输入一个链表,反转链表后,输出新链表的表头。
解题思路:题给的链表是一个单向链表,所以为了反转整个链表,需要将节点之间的指向问题进行整理,最后一个结点指向倒数第二个,倒数第二个指向倒数第三个,......,第二个指向第一个,第一个指向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