给定一个链表,两两交换其中相邻的节点,并返回交换后的链表。
你不能只是单纯的改变节点内部的值,而是需要实际的进行节点交换。
示例:
给定 1->2->3->4, 你应该返回 2->1->4->3.
tips : 原地交换,时间复杂度O(n), 空间复杂度O(1)
class Solution {
public:
ListNode* swapPairs(ListNode* head) {
if(head==NULL) {
return NULL;
}
ListNode* node=new ListNode(-1);
ListNode* init=node;
ListNode* swapA;
ListNode* nextHead;
node->next = head;
while (node->next!=NULL&&node->next->next!=NULL)
{
swapA=node->next;
if(node->next->next!=NULL) {
node->next=node->next->next;
nextHead=node->next->next;
node->next->next=swapA;
swapA->next=nextHead;
node=swapA;
}
}
return init->next;
}
};
本文介绍了一种链表操作算法,即两两交换链表中相邻节点的方法。该算法通过迭代方式实现,确保了时间复杂度为O(n),空间复杂度为O(1)。示例展示了如何将1->2->3->4转换为2->1->4->3,适用于需要原地修改链表结构的场景。
1133

被折叠的 条评论
为什么被折叠?



