国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

LeetCode 138:復(fù)制帶隨機(jī)指針的鏈表 Copy List with Random Poin

entner / 2422人閱讀

摘要:給定一個鏈表,每個節(jié)點(diǎn)包含一個額外增加的隨機(jī)指針,該指針可以指向鏈表中的任何節(jié)點(diǎn)或空節(jié)點(diǎn)。要求返回這個鏈表的深拷貝。提示你必須返回給定頭的拷貝作為對克隆列表的引用。確定隨機(jī)節(jié)點(diǎn)的關(guān)系之后再拆分鏈表。其時(shí)間復(fù)雜度為,空間復(fù)雜度為。

給定一個鏈表,每個節(jié)點(diǎn)包含一個額外增加的隨機(jī)指針,該指針可以指向鏈表中的任何節(jié)點(diǎn)或空節(jié)點(diǎn)。

要求返回這個鏈表的深拷貝

A linked list is given such that each node contains an additional random pointer which could point to any node in the list or null.

Return a deep copy of the list.

示例:

輸入:
{"$id":"1","next":{"$id":"2","next":null,"random":{"$ref":"2"},"val":2},"random":{"$ref":"2"},"val":1}

解釋:
節(jié)點(diǎn) 1 的值是 1,它的下一個指針和隨機(jī)指針都指向節(jié)點(diǎn) 2 。
節(jié)點(diǎn) 2 的值是 2,它的下一個指針指向 null,隨機(jī)指針指向它自己。

提示:

你必須返回給定頭的拷貝作為對克隆列表的引用。

Note:

You must return the copy of the given head as a reference to the cloned list.

解題思路:

由于需要考慮隨機(jī)指針,隨機(jī)指針指向的節(jié)點(diǎn)可能是null,也可能是鏈表的最后一個節(jié)點(diǎn),深拷貝下,你不能將新鏈表的隨機(jī)指針指向原鏈表的節(jié)點(diǎn),所以無法一遍得到新鏈表。

兩種解題方法,一種是拷貝所有節(jié)點(diǎn),暫存在一種數(shù)據(jù)結(jié)構(gòu)內(nèi),然后再遍歷一遍該數(shù)據(jù)結(jié)構(gòu),找到拷貝的節(jié)點(diǎn),確定隨機(jī)指針的指向。因?yàn)槊總€節(jié)點(diǎn)都要找到隨機(jī)指針指向的節(jié)點(diǎn),如果借助 散列表(字典) 其查找復(fù)雜度為 O(1) ,這樣可以把總時(shí)間復(fù)雜度降到 O(n) ,由于要暫存所有節(jié)點(diǎn),其空間復(fù)雜度為 O(n)。

另一種解題方法是需要三次遍歷得到結(jié)果,簡單來說就是先把每個節(jié)點(diǎn)拷貝,并把拷貝節(jié)點(diǎn)連接到原節(jié)點(diǎn)后面,依次類推。確定隨機(jī)節(jié)點(diǎn)的關(guān)系之后再拆分鏈表。是一種很巧妙的思路:

原鏈表:1->2->3
復(fù)制每個節(jié)點(diǎn)到原節(jié)點(diǎn)后面:1->1->2->2->3->3
復(fù)制隨機(jī)指針的指向關(guān)系
拆分鏈表:1->2->3, 1->2->3

復(fù)制隨機(jī)指針指向時(shí),原節(jié)點(diǎn)的隨機(jī)節(jié)點(diǎn)下一個節(jié)點(diǎn)即為新節(jié)點(diǎn)的隨機(jī)節(jié)點(diǎn)。假如原鏈表:1->2->3,節(jié)點(diǎn)1的隨機(jī)節(jié)點(diǎn)為3,復(fù)制節(jié)點(diǎn)之后:1->1->2->2->3->3

我們只需將新節(jié)點(diǎn)(原節(jié)點(diǎn)1的后一個節(jié)點(diǎn)1)指向原節(jié)點(diǎn)的隨機(jī)節(jié)點(diǎn)的后一個節(jié)點(diǎn)(原節(jié)點(diǎn)的隨機(jī)節(jié)點(diǎn)為3,而復(fù)制之后隨機(jī)節(jié)點(diǎn)3的后一個節(jié)點(diǎn)依然為3,但這個節(jié)點(diǎn)為新節(jié)點(diǎn)),最后拆分鏈表(鏈表拆分不影響節(jié)點(diǎn)指向關(guān)系)。其時(shí)間復(fù)雜度為 O(n),空間復(fù)雜度為 O(1)。

第一種方法:

Java:

class Solution {
    public Node copyRandomList(Node head) {
        if (head == null) return null;
        HashMap map = new HashMap<>();//借助hashMap
        Node newHead = new Node(0);//虛擬頭節(jié)點(diǎn)
        Node cur = newHead;//指針指向當(dāng)前節(jié)點(diǎn)
        Node tmp;
        while (head != null) {
            if (map.containsKey(head)) {//查詢原節(jié)點(diǎn)是否已存在于map
                tmp = map.get(head);//如果存在直接取value值
            } else {
                tmp = new Node(head.val);//不存在則新建一個值相同的節(jié)點(diǎn)
                map.put(head, tmp);//存入map,key為原節(jié)點(diǎn),value為新節(jié)點(diǎn)
            }
            cur.next = tmp;
            if (head.random != null) {//原節(jié)點(diǎn)的隨機(jī)節(jié)點(diǎn)不為空的情況下
                if (map.containsKey(head.random)) {//查詢該隨即節(jié)點(diǎn)是否已存在于map
                    tmp.random = map.get(head.random);//存在則直接將新節(jié)點(diǎn)的隨機(jī)指針指向其value值
                } else {
                    tmp.random = new Node(head.random.val);//不存在則新建一個值相同的隨機(jī)節(jié)點(diǎn)
                    map.put(head.random, tmp.random);//存入map,key為原節(jié)點(diǎn)的隨機(jī)節(jié)點(diǎn),value為新節(jié)點(diǎn)的隨機(jī)節(jié)點(diǎn)
                }
            }
            head = head.next;//刷新原鏈表當(dāng)前頭節(jié)點(diǎn)
            cur = tmp;//即cur=cur.next,刷新新鏈表當(dāng)前節(jié)點(diǎn)
        }
        return newHead.next;
    }
}

Python3:

class Solution:
    def copyRandomList(self, head: "Node") -> "Node":
        if not head: return None
        map = {}
        newHead = Node(val=0, next=None, random=None)
        cur = newHead
        while head:
            if head in map.keys():
                tmp = map.get(head)
            else:
                tmp = Node(val=head.val, next=None, random=None)
                map.setdefault(head, tmp)
            cur.next = tmp
            if head.random:
                if head.random in map.keys():
                    tmp.random = map.get(head.random)
                else:
                    tmp.random = Node(val=head.random.val, next=None, random=None)
                    map.setdefault(head.random, tmp.random)
            head = head.next
            cur = tmp
        return newHead.next
第二種方法:

Java:

class Solution {
    public Node copyRandomList(Node head) {
        if (head == null) return null;
        //復(fù)制節(jié)點(diǎn) 1->2->3 ==> 1->1->1->2->2->3->3
        Node cur = head;
        while (cur != null) {
            Node next = cur.next;
            Node tmp = new Node(cur.val);
            cur.next = tmp;
            tmp.next = next;
            cur = next;
        }
        //復(fù)制隨機(jī)指針
        cur = head;
        while (cur != null) {
            //cur.next.random=>新節(jié)點(diǎn)的隨機(jī)節(jié)點(diǎn)     cur.random.next=>原節(jié)點(diǎn)的隨機(jī)節(jié)點(diǎn)的下一個節(jié)點(diǎn)
            cur.next.random = cur.random == null ? null : cur.random.next;
            cur = cur.next.next;//鏈表擴(kuò)展一倍后肯定是偶數(shù)位鏈表,所以可以直接用cur.next.next
        }
        //分離節(jié)點(diǎn)
        cur = head;
        Node newHead = head.next;//新鏈表頭節(jié)點(diǎn)
        while (cur != null) {
            Node tmp = cur.next;
            cur.next = tmp.next;
            cur = cur.next;
            tmp.next = cur == null ? null : cur.next;
        }
        return newHead;
    }
}

Python3:

class Solution:
    def copyRandomList(self, head: "Node") -> "Node":
        if not head: return None
        cur = head
        while cur:
            next = cur.next
            tmp = Node(val=cur.val, next=next, random=None)
            cur.next = tmp
            cur = next
        cur = head
        while cur:
            cur.next.random = cur.random.next if cur.random else None
            cur = cur.next.next
        cur = head
        newHead = head.next
        while cur:
            tmp = cur.next
            cur.next = tmp.next
            cur = cur.next
            tmp.next = cur.next if cur else None
        return newHead

歡迎關(guān)注微.信公.眾號一起學(xué)習(xí):愛寫B(tài)ug

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/75626.html

相關(guān)文章

  • LeetCode 138復(fù)制隨機(jī)指針鏈表 Copy List with Random Poin

    摘要:給定一個鏈表,每個節(jié)點(diǎn)包含一個額外增加的隨機(jī)指針,該指針可以指向鏈表中的任何節(jié)點(diǎn)或空節(jié)點(diǎn)。要求返回這個鏈表的深拷貝。提示你必須返回給定頭的拷貝作為對克隆列表的引用。確定隨機(jī)節(jié)點(diǎn)的關(guān)系之后再拆分鏈表。其時(shí)間復(fù)雜度為,空間復(fù)雜度為。 給定一個鏈表,每個節(jié)點(diǎn)包含一個額外增加的隨機(jī)指針,該指針可以指向鏈表中的任何節(jié)點(diǎn)或空節(jié)點(diǎn)。 要求返回這個鏈表的深拷貝。 A linked list is g...

    Lucky_Boy 評論0 收藏0
  • leetcode138. Copy List with Random Pointer

    摘要:題目要求假設(shè)存在這樣一個鏈表,在鏈表的每一個節(jié)點(diǎn)中,除了記錄了自身值和指向下一個節(jié)點(diǎn)的指針,還有一個隨機(jī)指針指向鏈表中任意一個節(jié)點(diǎn)。所以可以在兩次遍歷后完成任務(wù)。最后一圈遍歷,我們調(diào)整指針,恢復(fù)原鏈表和塑造新鏈表。 題目要求 A linked list is given such that each node contains an additional random pointer ...

    Kross 評論0 收藏0
  • LeetCode 133:克隆圖 Clone Graph

    摘要:解題思路涉及到圖的遍歷無非就是深度優(yōu)先搜索廣度優(yōu)先搜索,可以先看前幾日的這篇文章就需要借助隊(duì)列實(shí)現(xiàn),可以借助棧也可以直接用遞歸實(shí)現(xiàn)。 題目: 給定無向連通圖中一個節(jié)點(diǎn)的引用,返回該圖的深拷貝(克隆)。圖中的每個節(jié)點(diǎn)都包含它的值 val(Int) 和其鄰居的列表(list[Node])。 Given a reference of a node in a connected undirec...

    Simon 評論0 收藏0
  • [Leetcode] Copy List with Random Pointer 復(fù)制隨機(jī)指針

    摘要:棧迭代復(fù)雜度時(shí)間空間如果不算新鏈表的空間則是思路由于隨機(jī)指針有可能產(chǎn)生環(huán)路,我們不能直接沿著隨機(jī)指針的方向一個一個復(fù)制。同時(shí)我們又不能沿著指針直接復(fù)制,因?yàn)槲覀儾恢离S機(jī)指針?biāo)赶虻男鹿?jié)點(diǎn)是哪個。 Copy List with Random Pointer A linked list is given such that each node contains an additiona...

    Olivia 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<