328. 奇偶链表
1.题目描述
给定一个单链表,把所有的奇数节点和偶数节点分别排在一起。请注意,这里的奇数节点和偶数节点指的是节点编号的奇偶性,而不是节点的值的奇偶性。
请尝试使用原地算法完成。你的算法的空间复杂度应为 O(1),时间复杂度应为 O(nodes),nodes 为节点总数。
示例 1:
示例 2:
说明:
1.应当保持奇数节点和偶数节点的相对顺序。
2.链表的第一个节点视为奇数节点,第二个节点视为偶数节点,以此类推。
2.思路
1.分别把奇数节点和偶数节点串起来
2.偶数节点接在奇数节点后面
3.返回头节点
3.代码
/**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* ListNode *next;
* ListNode(int x) : val(x), next(NULL) {}
* };
*/
class Solution {
public:
ListNode* oddEvenList(ListNode* head) {
if(head == NULL){
return head;
}
ListNode* odd = head;
ListNode* even = head->next;
ListNode* evenHead = even;
while(even!= NULL && even->next != NULL){
odd->next = even->next;
odd = odd->next;
even->next = odd->next;
even = even->next;
}
//偶数链表接在奇数链表后面
odd->next = evenHead;
return head;
}
};
4.复杂度分析
时间复杂度:O(n)
空间复杂度:O(1)