赞
踩
给定一个链表,两两交换其中相邻的节点,并返回交换后的链表。
示例:
给定 1->2->3->4, 你应该返回 2->1->4->3.
说明:
解题思路
我们首先需要建立pre
、node1
、node2
和lat
四个指针即可。
pre node1 node2 lat
h -> 1 -> 2 -> 3 -> 4
然后pre->next=node2;node2.next=node1;node1.next=lat
-----------
| |
h 1 <- 2 -> 3 -> 4
| |
-----------
接着更新四个指针即可。
class Solution: def swapPairs(self, head): """ :type head: ListNode :rtype: ListNode """ h = ListNode(-1) h.next = head pre = h while pre.next != None and pre.next.next != None: node1 = pre.next node2 = node1.next lat = node2.next pre.next = node2 node2.next = node1 node1.next = lat pre = node1 return h.next
在结合Leetcode 206:反转链表(最详细解决方案!!!)和Leetcode 92:反转链表 II(最详细解决方案!!!)这篇文章,我相信大家对链表反转操作中的指针是放在循环体内还是循环体外会有一些新的认识!
我将该问题的其他语言版本添加到了我的GitHub Leetcode
如有问题,希望大家指出!!!
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。