题目:328. 奇偶链表
给定一个单链表,把所有的奇数节点和偶数节点分别排在一起。请注意,这里的奇数节点和偶数节点指的是节点编号的奇偶性,而不是节点的值的奇偶性。
请尝试使用原地算法完成。你的算法的空间复杂度应为 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
说明:
- 应当保持奇数节点和偶数节点的相对顺序。
- 链表的第一个节点视为奇数节点,第二个节点视为偶数节点,以此类推。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/odd-even-linked-list
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
基本思想:一次遍历
- 两个指针分别指向第奇数个节点和第偶数个节点,依次向后遍历
cpp版本
/**
* 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) {
ListNode* p_odd = new ListNode(-1), *p_even = new ListNode(-1), *p = head;
ListNode* h_odd = p_odd, *h_even = p_even;
while(p){
p_odd->next = p;
p_odd = p_odd->next;
p = p->next;
if(p){
p_even->next = p;
p_even = p_even->next;
p = p->next;
}
}
p_odd->next = h_even->next;
p_even->next = NULL;
return h_odd->next;
}
};
python版本
# Definition for singly-linked list.
# class ListNode:
# def __init__(self, val=0, next=None):
# self.val = val
# self.next = next
class Solution:
def oddEvenList(self, head: ListNode) -> ListNode:
p_odd = ListNode()
p_even = ListNode()
p = head
h_odd = p_odd
h_even = p_even
while p:
p_odd.next = p
p_odd = p_odd.next
p = p.next
if p:
p_even.next = p
p_even = p_even.next
p = p.next
p_odd.next = h_even.next
p_even.next = None
return h_odd.next