成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

[Leetcode] Swap Nodes in Pairs Reverse Nodes in k-

TZLLOG / 3029人閱讀

摘要:三指針法復(fù)雜度時(shí)間空間思路基本的操作鏈表,見注釋。注意使用頭節(jié)點(diǎn)方便操作頭節(jié)點(diǎn)。翻轉(zhuǎn)后,開頭節(jié)點(diǎn)就成了最后一個(gè)節(jié)點(diǎn)。

Swap Nodes in Pairs

Given a linked list, swap every two adjacent nodes and return its head.

For example, Given 1->2->3->4, you should return the list as 2->1->4->3.

Your algorithm should use only constant space. You may not modify the values in the list, only nodes itself can be changed.

三指針法 復(fù)雜度

時(shí)間 O(N) 空間 O(1)

思路

基本的操作鏈表,見line注釋。注意使用dummy頭節(jié)點(diǎn)方便操作頭節(jié)點(diǎn)。

代碼
public class Solution {
    public ListNode swapPairs(ListNode head) {
        ListNode dummy = new ListNode(0);
        dummy.next = head;
        // curr是待交換的兩個(gè)節(jié)點(diǎn)前面那個(gè)節(jié)點(diǎn)
        ListNode curr = dummy;
        while(curr != null && curr.next != null && curr.next.next != null){
            ListNode third = curr.next.next.next;
            ListNode second = curr.next.next;
            ListNode first = curr.next;
            // 把第二個(gè)節(jié)點(diǎn)的next置為第一個(gè)節(jié)點(diǎn)
            second.next = first;
            // 把當(dāng)前節(jié)點(diǎn)的next置為第二個(gè)節(jié)點(diǎn)
            curr.next = second;
            // 把第一個(gè)節(jié)點(diǎn)的next置為第三個(gè)節(jié)點(diǎn)
            first.next = third;
            // 將當(dāng)前節(jié)點(diǎn)置為第一個(gè)節(jié)點(diǎn),繼續(xù)下一輪交換(此時(shí)first實(shí)際已經(jīng)是第二個(gè)節(jié)點(diǎn)了)
            curr = first;
        }
        return dummy.next;
    }
}

不想用那么多指針?

public class Solution {
    public ListNode swapPairs(ListNode head) {
        ListNode dummy = new ListNode(0);
        dummy.next = head;
        ListNode curr = dummy;
        while(curr != null && curr.next != null && curr.next.next != null){
            ListNode tmp = curr.next.next.next; // tmp - 3
            curr.next.next.next = curr.next;    // 3 - 1
            curr.next = curr.next.next;         // 1 - 2
            curr.next.next.next = tmp;          // 3 - tmp
            curr = curr.next.next;              // 0 - 2
        }
        return dummy.next;
    }
}
Reverse Nodes in k-Group

Given a linked list, reverse the nodes of a linked list k at a time and return its modified list.

If the number of nodes is not a multiple of k then left-out nodes in the end should remain as it is.

You may not alter the values in the nodes, only nodes itself may be changed.

Only constant memory is allowed.

For example, Given this linked list: 1->2->3->4->5

For k = 2, you should return: 2->1->4->3->5

For k = 3, you should return: 3->2->1->4->5

分段反轉(zhuǎn) 復(fù)雜度

時(shí)間 O(N) 空間 O(1)

思路

其實(shí)就是每K個(gè)節(jié)點(diǎn)執(zhí)行一次反轉(zhuǎn)鏈表,不過這里有幾點(diǎn)要注意:

如果剩余節(jié)點(diǎn)不足K個(gè)則不執(zhí)行反轉(zhuǎn),所以要先判斷是否可以反轉(zhuǎn)

為了拼接這個(gè)反轉(zhuǎn)過后的鏈表,我們需要類似Reverse Linked List II一樣的操作,即記錄下該段鏈表的開頭節(jié)點(diǎn),這個(gè)開頭節(jié)點(diǎn)的前一個(gè)節(jié)點(diǎn),該鏈表的最后一個(gè)節(jié)點(diǎn),和這最后一個(gè)節(jié)點(diǎn)的下一個(gè)節(jié)點(diǎn)。翻轉(zhuǎn)后,開頭節(jié)點(diǎn)就成了最后一個(gè)節(jié)點(diǎn)。

拆分成子函數(shù),清晰易懂

K等于1的時(shí)候直接返回原鏈表

代碼
public class Solution {
    public ListNode reverseKGroup(ListNode head, int k) {
        if(k == 1) return head;
        ListNode dummy = new ListNode(0);
        dummy.next = head;
        ListNode curr = dummy;
        while(curr != null && curr.next != null && curr.next.next != null){
            // 檢測(cè)是否有足夠節(jié)點(diǎn)供反轉(zhuǎn),不足直接退出
            if(!hasEnoughNodes(curr.next, k)) break;
            // 記錄下第一個(gè)節(jié)點(diǎn),反轉(zhuǎn)后成為最后一個(gè)節(jié)點(diǎn)
            ListNode last = curr.next;
            // 從這第一個(gè)節(jié)點(diǎn)開始反轉(zhuǎn)K個(gè)節(jié)點(diǎn)
            ListNode[] nodes = reverseK(last, k);
            // 將第0個(gè)節(jié)點(diǎn)的next接上新鏈表的頭節(jié)點(diǎn)
            curr.next = nodes[0];
            // 將新鏈表的尾節(jié)點(diǎn)的后一個(gè)節(jié)點(diǎn)置為后一段鏈表的頭節(jié)點(diǎn)
            last.next = nodes[1];
            // 準(zhǔn)備反轉(zhuǎn)下一段鏈表
            curr = last;
        }
        return dummy.next;
    }
    
    private boolean hasEnoughNodes(ListNode runner, int k){
        int remains = 0;
        while(runner != null && remains < k){
            remains++;
            runner = runner.next;
        }
        if(remains < k) return false;
        return true;
    }
    
    private ListNode[] reverseK(ListNode p1, int k){
        ListNode p2 = p1.next;
        // 反轉(zhuǎn)K個(gè)節(jié)點(diǎn)
        while(p2 != null && k > 1){
            ListNode tmp = p2.next;
            p2.next = p1;
            p1 = p2;
            p2 = tmp;
            k--;
        }
        // 返回值第一個(gè)是新的鏈表頭節(jié)點(diǎn),第二個(gè)是下一段鏈表的頭節(jié)點(diǎn)
        ListNode[] res = {p1, p2};
        return res;
    } 
}

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

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/64686.html

相關(guān)文章

  • 【LC總結(jié)】翻轉(zhuǎn)鏈表 Swap in Pairs, Reverse in k-Group, Reve

    摘要:注意這里,只要走到第位 Swap Nodes in Pairs For example,Given 1->2->3->4, you should return the list as 2->1->4->3. Solution public class Solution { public ListNode swapPairs(ListNode head) { if...

    Steve_Wang_ 評(píng)論0 收藏0
  • leetcode24 Swap Nodes in Pairs 交換鏈表中相鄰兩個(gè)節(jié)點(diǎn)

    摘要:題目要求翻譯過來就是將鏈表中相鄰兩個(gè)節(jié)點(diǎn)交換順序,并返回最終的頭節(jié)點(diǎn)。思路這題的核心解題思路在于如何不占用額外的存儲(chǔ)空間,就改變節(jié)點(diǎn)之間的關(guān)系。 題目要求 Given a linked list, swap every two adjacent nodes and return its head. For example, Given 1->2->3->4, you should r...

    GT 評(píng)論0 收藏0
  • leetcode 24 Swap Nodes in Pairs

    摘要:最后返回頭節(jié)點(diǎn)。同時(shí)題目要求只能占用常數(shù)空間,并且不能改變節(jié)點(diǎn)的值,改變的是節(jié)點(diǎn)本身的位置。翻轉(zhuǎn)是以兩個(gè)節(jié)點(diǎn)為單位的,我們新聲明一個(gè)節(jié)點(diǎn)表示當(dāng)前操作到的位置。每次操作結(jié)束,將指針后移兩個(gè)節(jié)點(diǎn)即可。執(zhí)行操作前要確定操作的兩個(gè)節(jié)點(diǎn)不為空。 題目詳情 Given a linked list, swap every two adjacent nodes and return its head....

    heartFollower 評(píng)論0 收藏0
  • leetcode 部分解答索引(持續(xù)更新~)

    摘要:前言從開始寫相關(guān)的博客到現(xiàn)在也蠻多篇了。而且當(dāng)時(shí)也沒有按順序?qū)懍F(xiàn)在翻起來覺得蠻亂的。可能大家看著也非常不方便。所以在這里做個(gè)索引嘻嘻。順序整理更新更新更新更新更新更新更新更新更新更新更新更新更新更新更新更新 前言 從開始寫leetcode相關(guān)的博客到現(xiàn)在也蠻多篇了。而且當(dāng)時(shí)也沒有按順序?qū)憽F(xiàn)在翻起來覺得蠻亂的??赡艽蠹铱粗卜浅2环奖恪K栽谶@里做個(gè)索引嘻嘻。 順序整理 1~50 1...

    leo108 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

閱讀需要支付1元查看
<