反转单向和双向链表

【题目】 分别实现反转单向链表和反转双向链表的函数。 

【要求】 如果链表长度为 N,时间复杂度要求为 O(N),额外空间复杂度要求为 O(1)。

public class ReverseList {

    class Node {
        private int value;
        private Node next;

        public Node(int value) {
            this.value = value;
        }
    }

    class DoubleNode {
        private int value;
        private DoubleNode next;
        private DoubleNode last;

        public DoubleNode(int value) {
            this.value = value;
        }
    }

    /**
     * 反转单链表
     * @param head
     * @return
     */
    public Node reverseList(Node head) {
        // pre代指当前节点的前一个节点
        Node pre = null;
        // next代指当前节点的后一个节点
        Node next = null;
        // cur代指当前节点
        Node cur = head;

        // 当前节点不为空
        while (cur != null) {
            // next指向当前节点的后一个节点
            next = cur.next;

            // 当前节点反转指针,把指针指向前一个节点
            cur.next = pre;

            // 反转后pre当前节点前一个节点向后移
            pre = cur;
            // cur当前节点向后移
            cur = next;
        }

        // 循环走完之后,cur指向空,pre指向了反转后的头节点
        return pre;
    }

    /**
     * 反转双向链表
     * @param head
     * @return
     */
    public DoubleNode reverseList(DoubleNode head) {
        // pre代指当前节点的前一个节点
        DoubleNode pre = null;
        // next代指当前节点的后一个节点
        DoubleNode next = null;
        // cur指向当前节点
        DoubleNode cur = head;

        while (cur != null) {
            // 使next 指向当前节点的后一个节点
            next = cur.next;

            // 反转节点指向
            // 当前节点的next指针指向当前节点的前一个节点
            cur.next = pre;
            // 当前节点的last指针指向当前节点的后一个节点
            cur.last = next;

            pre = cur;
            cur = next;
        }
        return pre;
    }
    
}

#链表#
数据结构与算法 文章被收录于专栏

笔者学习数据结构与算法的心得与经验。

全部评论

相关推荐

点赞 评论 收藏
分享
找工作勤劳小蜜蜂:自我描述部分太差,完全看不出想从事什么行业什么岗位,也看不出想在哪个地区发展,这样 会让HR很犹豫,从而把你简历否决掉。现在企业都很注重员工稳定性和专注性,特别对于热爱本行业的员工。 你实习的工作又太传统的it开发(老旧),这部分公司已经趋于被淘汰,新兴的互联网服务业,比如物流,电商,新传媒,游戏开发和传统的It开发有天然区别。不是说传统It开发不行,而是就业岗位太少,基本趋于饱和,很多老骨头还能坚持,不需要新血液。 工作区域(比如长三角,珠三角,成渝)等也是HR考虑的因素之一,也是要你有个坚定的决心。否则去几天,人跑了,HR会被用人单位骂死。
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务