奇偶链表
一、LeetCode题解
瞧一瞧~
- 博健的LeetCode题解:Gitbook版本传送门
- 博健的LeetCode题解:CSDN传送门
- 前端进阶笔记:Gitbook传送门
二、算法题
题目
给定一个单链表,把所有的奇数节点和偶数节点分别排在一起。请注意,这里的奇数节点和偶数节点指的是节点编号的奇偶性,而不是节点的值的奇偶性。
请尝试使用原地算法完成。你的算法的空间复杂度应为 O(1),时间复杂度应为 O(n),n 为节点总数。
示例 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
说明:
应当保持奇数节点和偶数节点的相对顺序。
链表的第一个节点视为奇数节点,第二个节点视为偶数节点,以此类推。
解法一(双指针)
思路
- 定义三个指针,分别记录奇数链表、偶数链表、偶数链表的head节点
- 记录奇偶链表,最后将偶数链表接到奇数链表的尾端
- 奇数链表节点 = 偶数链表最新节点的下一个
- 偶数链表节点 = 奇数链表最新节点的下一个
代码
var oddEvenList = function(head) {
if(!head) return ;
var odd = head; // 奇数链表
var even = head.next; // 偶数链表
var evenHead = even // 偶数链表头
while(even && even.next ){
odd.next = even.next
odd = odd.next
even.next = odd.next
even = even.next
}
odd.next = evenHead
return head
};