You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Given a linked list, swap every two adjacent nodes and return its head. You must solve the problem without modifying the values in the list's nodes (i.e., only nodes themselves may be changed.)
Example 1:
**Input:** head = [1,2,3,4]
**Output:** [2,1,4,3]
Example 2:
**Input:** head = []
**Output:** []
Example 3:
**Input:** head = [1]
**Output:** [1]
Constraints:
The number of nodes in the list is in the range [0, 100].
请点击下方图片观看讲解视频
Click below image to watch YouTube Video
Given a linked list, swap every two adjacent nodes and return its head. You must solve the problem without modifying the values in the list's nodes (i.e., only nodes themselves may be changed.)
Example 1:
Example 2:
Example 3:
Constraints:
[0, 100]
.0 <= Node.val <= 100
这道题不算难,是基本的链表操作题,我们可以分别用递归和迭代来实现。对于迭代实现,还是需要建立 dummy 节点,注意在连接节点的时候,最好画个图,以免把自己搞晕了,参见代码如下:
解法一:
递归的写法就更简洁了,实际上利用了回溯的思想,递归遍历到链表末尾,然后先交换末尾两个,然后依次往前交换:
解法二:
Github 同步地址:
#24
类似题目:
Reverse Nodes in k-Group
Swapping Nodes in a Linked List
参考资料:
https://leetcode.com/problems/swap-nodes-in-pairs
https://leetcode.com/problems/swap-nodes-in-pairs/discuss/11030/My-accepted-java-code.-used-recursion.
LeetCode All in One 题目讲解汇总(持续更新中...)
(欢迎加入博主的知识星球,博主将及时答疑解惑,并分享刷题经验与总结,快快加入吧~)
喜欢请点赞,疼爱请打赏❤️~.~
微信打赏
|
Venmo 打赏
---|---
The text was updated successfully, but these errors were encountered: