leetcode 328. 奇偶链表 easy
题目描述:
给定一个单链表,把所有的奇数节点和偶数节点分别排在一起。请注意,这里的奇数节点和偶数节点指的是节点编号的奇偶性,而不是节点的值的奇偶性。
请尝试使用原地算法完成。你的算法的空间复杂度应为 O(1),时间复杂度应为 O(nodes),nodes 为节点总数。
说明:
- 应当保持奇数节点和偶数节点的相对顺序。
- 链表的第一个节点视为奇数节点,第二个节点视为偶数节点,以此类推。
解题思路:
简单
代码:
class Solution {
public:
ListNode* oddEvenList(ListNode* head) {
if(!head)
return head;
ListNode odd_dummy(0),even_dummy(0);
ListNode *odd=&odd_dummy, *even=&even_dummy,*cur=head;
int i=1;
while(cur){
if(i & 1){odd->next=cur;odd=odd->next;}
else {even->next=cur;even=even->next;}
++i;
cur=cur->next;
}
odd->next=even_dummy.next;
even->next=nullptr;
return odd_dummy.next;
}
};