zoukankan      html  css  js  c++  java
  • 剑指 Offer 35. 复杂链表的复制

    请实现 copyRandomList 函数,复制一个复杂链表。在复杂链表中,每个节点除了有一个 next 指针指向下一个节点,还有一个 random 指针指向链表中的任意节点或者 null。

    示例 1:

     

    输入:head = [[7,null],[13,0],[11,4],[10,2],[1,0]]
    输出:[[7,null],[13,0],[11,4],[10,2],[1,0]]
    示例 2:

     

    输入:head = [[1,1],[2,1]]
    输出:[[1,1],[2,1]]
    示例 3:

     

    输入:head = [[3,null],[3,0],[3,null]]
    输出:[[3,null],[3,0],[3,null]]
    示例 4:

    输入:head = []
    输出:[]
    解释:给定的链表为空(空指针),因此返回 null。
     

    提示:

    -10000 <= Node.val <= 10000
    Node.random 为空(null)或指向链表中的节点。
    节点数目不超过 1000 。

    来源:力扣(LeetCode)

    原地修改

    /*
    // Definition for a Node.
    class Node {
        int val;
        Node next;
        Node random;
    
        public Node(int val) {
            this.val = val;
            this.next = null;
            this.random = null;
        }
    }
    */
    class Solution {
        public Node copyRandomList(Node head) {
            if(head==null)return head;
            Node cur=head;
            //copy the original list
            while(cur!=null){
                Node copy=new Node(cur.val);
                copy.next=cur.next;
                cur.next=copy;
                cur=cur.next.next;
            }
            //copy the copied nodes' random pointer
            cur=head;
            while(cur!=null){
                if(cur.random!=null)// be aware of the nullptr
                    cur.next.random=cur.random.next;
                cur=cur.next.next;
            }
            //split the list into halves
            cur=head;
            Node res=head.next;
            Node curCopy=head.next;
            while(cur!=null){
                cur.next=cur.next.next;
                cur=cur.next;
                if(curCopy.next!=null){
                    curCopy.next=curCopy.next.next;
                    curCopy=curCopy.next;//curCopy jumps over the next duplicate node
                }
            }
            return res;   
        }
    }

    哈希表

    /*
    // Definition for a Node.
    class Node {
        int val;
        Node next;
        Node random;
    
        public Node(int val) {
            this.val = val;
            this.next = null;
            this.random = null;
        }
    }
    */
    class Solution {
        public Node copyRandomList(Node head) {
            if(head==null)return head;
            Map<Node,Node>map=new HashMap<>();
            for(Node cur=head;cur!=null;cur=cur.next)
                map.put(cur,new Node(cur.val));
            for(Node cur=head;cur!=null;cur=cur.next){
                map.get(cur).next=map.get(cur.next);
                map.get(cur).random=map.get(cur.random);
            }
            return map.get(head);
        }
    }

  • 相关阅读:
    与你的领导意见不一致时你会怎么做?
    调用caffe脚本将图片转换为了lmdb格式
    第04组 Alpha冲刺(4/4)
    第04组 Alpha冲刺(3/4)
    第04组 Alpha冲刺(2/4)
    第04组 Alpha冲刺(1/4)
    2019 SDN上机第3次作业
    2019 SDN阅读作业
    2019 SDN上机第2次作业
    2019 SDN上机第1次作业
  • 原文地址:https://www.cnblogs.com/xxxsans/p/13812243.html
Copyright © 2011-2022 走看看