博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Swap Nodes in Pairs
阅读量:6036 次
发布时间:2019-06-20

本文共 1085 字,大约阅读时间需要 3 分钟。

Given a linked list, swap every two adjacent nodes and return its head.

For example,

Given 1->2->3->4, you should return the list as 2->1->4->3.

Your algorithm should use only constant space. You may not modify the values in the list, only nodes itself can be changed.

这一题要求两两交换链表中的元素。题目要求常数时间,即无法使用递归解法。

主要思路是两个两个结点<node1,node2>进行处理,为了维护连接,需要维护一个prev头元素,操作之前指向node1,操作之后指向node2。为了防止头元素的问题,需要再次用到dummy技巧。每次处理时,实际是需要将prev->node1,node1->node2,node2->node2.next这三条指向进行重定向,先交换的不能影响后续交换需要用到的连接,实际操作时可以画个图来具体看看先后顺序。时间复杂度O(n),空间复杂度O(1)。代码如下:

class Solution(object):    def swapPairs(self, head):        """        :type head: ListNode        :rtype: ListNode        """        if not head or not head.next:            return head        dummy = ListNode(-1)        dummy.next = head        prev = dummy        cur = head         while cur and cur.next:                        prev.next = cur.next            cur.next = prev.next.next            prev.next.next = cur            prev = cur            cur = cur.next        return dummy.next

 

转载于:https://www.cnblogs.com/sherylwang/p/5430974.html

你可能感兴趣的文章
转 网络IO模型:同步IO和异步IO,阻塞IO和非阻塞IO
查看>>
求带分数(蓝桥杯)
查看>>
Bootstrap系列 -- 11. 基础表单
查看>>
格拉西安《智慧书》中最有价值的23条法则
查看>>
7款经典炫酷的HTML5/jQuery动画应用示例及源码
查看>>
那些年我们一起追过的缓存写法(四)
查看>>
mssql手工注入
查看>>
zoj 3203 Light Bulb,三分之二的基本问题
查看>>
Oracle如何删除表中重复记录
查看>>
洛谷八月月赛Round1凄惨记
查看>>
Retrofit 入门学习
查看>>
【树莓派】树莓派网络配置:静态IP、无线网络、服务等
查看>>
JavaScript——双向链表实现
查看>>
抽象类和借口的区别
查看>>
nginx的location root 指令
查看>>
zDiaLog弹出层
查看>>
linux不常用但很有用的命令(持续完善)
查看>>
NFine常见错误
查看>>
zabbix报警媒介------>微信报警
查看>>
使用视图的好处
查看>>