24. 两两交换链表中的节点

作者: 不爱去冒险的少年y | 来源:发表于2018-05-30 09:01 被阅读2次

    24. 两两交换链表中的节点

    给定一个链表,两两交换其中相邻的节点,并返回交换后的链表。

    示例:

    给定1->2->3->4, 你应该返回2->1->4->3.

    说明:

    你的算法只能使用常数的额外空间。

    你不能只是单纯的改变节点内部的值,而是需要实际的进行节点交换。

    # class ListNode:

    #    def __init__(self, x):

    #        self.val = x

    #        self.next = None

    class Solution:

        def swapPairs(self, head):

            """

            :type head: ListNode

            :rtype: ListNode

            """

            head = self.duigui(head)

            return head

        def duigui(self, tree):

            if tree == None or tree.next == None:

                return tree

            else:

                next_data = tree

                nnext_data = tree.next

                next_data.next = nnext_data.next

                nnext_data.next = next_data

                # tree.next = nnext_data

                next_data.next = self.duigui(next_data.next)

                return nnext_data

    相关文章

      网友评论

        本文标题:24. 两两交换链表中的节点

        本文链接:https://www.haomeiwen.com/subject/mottsftx.html