剑指Offer(链表)-反转链表

独自空忆成欢 提交于 2020-03-26 09:52:26

  (反转链表)题目描述:


输入一个链表,反转链表后,输出新链表的表头。


  解题思路:题给的链表是一个单向链表,所以为了反转整个链表,需要将节点之间的指向问题进行整理,最后一个结点指向倒数第二个,倒数第二个指向倒数第三个,......,第二个指向第一个,第一个指向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;
    }
}

  

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!