交换链表相邻的两个元素
题目:给定一个链表,交换每个相邻的元素,最后返回新的链表节点。
ListNode *swapNodes(ListNode *head)
{
if(head == NULL || head->next == NULL)
return head;
ListNode *dummyNode = new ListNode(0);
dummyNode->next = head;
ListNode *tmpNode = dummyNode;
while(tmpNode->next != NULL && tmpNode->next->next != NULL)
{
//用于临时存储一个节点
ListNode *prev = tmpNode->next;
//改变两个节点prev节点的next指针
tmpNode->next = tmpNode->next->next;
prev->next = tmpNode->next->next;
//改变两个节点的next指针
tmpNode->next->next = prev;
tmpNode = prev;
}
return dummyNode->next;
}
另一种写法:
原理一样,上一种方法只保留了要交换两元素的前一个元素(while循环内再借助临时变量完成指针转换),本方法保留了三个元素(两个要交换的元素及前一个元素),开头的两个元素交换的话前一个元素用dummyNode。
//另一种写法,原理一样,上一种方法只保留了要交换两元素的前一个元素(while循环内再借助用临时变量完成指针转换),本方法保留了三个(两个要交换的元素及前一个元素),开头的两个元素交换的话前一个元素用dummyNode。
ListNode *swapPairs(ListNode *head)
{
if(head == NULL || head->next == NULL)
return head;
ListNode *dummyNode = new ListNode(0);
dummyNode->next = head;
ListNode *prev = dummyNode;
ListNode *node1 = head, node2 = head->next;
while(node1 != NULL && node1->next != NULL)
{
//三个元素都有了,prev、node1、node2
node2 = node1->next;
//改变两个元素prev节点的next指针
prev->next = node2;
node1->next = node2->next;
//改变两个元素的next指针
node2->next = node1;
prev = node1;
node1 = prev->next;
}
return dummyNode->next;
}