簡體   English   中英

反向單鏈表

[英]Reverse single linked list

我正在實施“反向單鏈表,就地執行”任務。 我想出了這個解決方案:

/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode(int x) { val = x; }
 * }
 */
public class Solution {
    public ListNode reverseList(ListNode head) {
        if (head == null) {
            return null;
        }

        if(head.next==null) return head;

        ListNode n = head;
        ListNode r = null;
        ListNode temp = null;

        while (n != null) {
            temp = n;
            n = n.next;
            temp.next = r;
            r = temp;
        }

        return r;
    }
}

它有效:

1 2 3 4 5 
5 4 3 2 1 

但是當我想確保它是正確的方法時,我在網上看到的所有解決方案看起來都像反向單鏈表,所以我開始質疑自己......我的解決方案有什么問題? 時間復雜度看起來像 O(n) 空間 com。 O(1)...我錯了嗎? 提前致謝!

不確定你在問什么。 您的實現與鏈接中的實現幾乎一模一樣。 兩種實現的時間復雜度均為O(n) O(1) ,空間復雜度為O(1) 當然,列表本身的空間復雜度是O(n)

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM