1. 程式人生 > 其它 >LeetCode328:奇偶連結串列

LeetCode328:奇偶連結串列

技術標籤:我的leetcode刷題連結串列leetcodec++指標

一、題目描述

    給定一個單鏈表,把所有的奇數節點和偶數節點分別排在一起。請注意,這裡的奇數節點和偶數節點指的是節點編號的奇偶性,而不是節點的值的奇偶性。
    請嘗試使用原地演算法完成。你的演算法的空間複雜度應為 O(1),時間複雜度應為 O(nodes),nodes 為節點總數。
示例 1:

輸入: 1->2->3->4->5->NULL
輸出: 1->3->5->2->4->NULL

示例 2:

輸入: 2->1->3->5->6->4->7->NULL 
輸出: 2->3->6->7->1->5->4->NULL

說明:
    應當保持奇數節點和偶數節點的相對順序。
    連結串列的第一個節點視為奇數節點,第二個節點視為偶數節點,以此類推。

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode() : val(0), next(nullptr) {}
 *     ListNode(int x) : val(x), next(nullptr) {}
 *     ListNode(int x, ListNode *next) : val(x), next(next) {}
 * };
 */
class Solution { public: ListNode* oddEvenList(ListNode* head) { } };

二、解題思路

    看圖
在這裡插入圖片描述
在這裡插入圖片描述
在這裡插入圖片描述
在這裡插入圖片描述
在這裡插入圖片描述

	while(p->next!=nullptr&&q->next!=nullptr){        
                p->next=q->next;
                p=p->next;
                q->next=p->next;
                q=
q->next; }

三、我的程式碼

    直接在力扣上寫的。

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode() : val(0), next(nullptr) {}
 *     ListNode(int x) : val(x), next(nullptr) {}
 *     ListNode(int x, ListNode *next) : val(x), next(next) {}
 * };
 */
class Solution {
public:
    ListNode* oddEvenList(ListNode* head) {
        if(head==nullptr)
            return head;
        ListNode* p=head;
        ListNode* head1=head->next;
        ListNode* q=head->next;
        while(p->next!=nullptr&&q->next!=nullptr){        
                p->next=q->next;
                p=p->next;
                q->next=p->next;
                q=q->next;
        }
        p->next=head1;
        return head;
    }
};

四、測試結果

在這裡插入圖片描述