算法每日一刷

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
    }
上一篇下一篇

猜你喜欢

热点阅读