LeetCode算法题-24. 两两交换链表中的节点(Swift
2019-10-15 本文已影响0人
entre_los_dos
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/swap-nodes-in-pairs
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
题目
给定一个链表,两两交换其中相邻的节点,并返回交换后的链表。
你不能只是单纯的改变节点内部的值,而是需要实际的进行节点交换。
示例:
给定 1->2->3->4, 你应该返回 2->1->4->3.
方法
func swapPairs(_ head: ListNode?) -> ListNode? {
let resultNode: ListNode = ListNode(0)
var currentNode: ListNode? = resultNode
var headCurrentNode = head
while (headCurrentNode != nil) {
let node1 = headCurrentNode
if node1!.next != nil {
headCurrentNode = headCurrentNode?.next?.next
currentNode!.next = node1!.next
currentNode!.next?.next = node1
currentNode = currentNode!.next?.next
currentNode?.next = nil
}else {
currentNode!.next = node1
currentNode = currentNode!.next
headCurrentNode = headCurrentNode?.next
}
}
return resultNode.next
}