两两交换链表中的节点

简介: 前言文本已收录至我的GitHub仓库,欢迎Star:github.com/bin39232820…种一棵树最好的时间是十年前,其次是现在

絮叨


哈哈,又是一个小小的算法题分享,这题是我面阿里的时候的算法题,当时自己完成没懂啥意思,哎,惭愧。今天小六六跟大家一起再来好好啃一下他吧


题目


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

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

 

示例:

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

大家一起跟小六六来读题,其实题目的意思还是很简单就是说每2个节点为一组,每组里面的节点,相互交互位置。就好比。


题解一 递归


对于递归,小六六先说一下我们应该关注啥

  • 递归的返回值
  • 递归的出口是啥(终止递归的条件)
  • 递归做了什么逻辑

在本题中分别对应如下

  • 返回值:交换完成的子链表
  • 终止条件:head 为空指针或者 next 为空指针,也就是当前无节点或者只有一个节点,无法进行交换
  • 调用单元的逻辑:head 为空指针或者 next 为空指针,也就是当前无节点或者只有一个节点,无法进行交换

怎么说了,很抽象,我是想了好久,简单解释一下,就好比 1234 ,那第一次递归就是 12 第二次递归就是 34 然后把 第二次递归后的结果,放到 2 1互换之后的位置。来看看代码,好好想想,烧脑


红圈中就是题解,代码虽少,但是吧,还是需要很多思考的,其实就是借助了一个中心变量,就好比 A和B要交换,那么我A先跟C交换,然后A和B交换,最后B在和C交换。这段是真的绕


题解二


大家好好想想吧,就是那种感觉自己的思维被堵住一样,哎。。


结尾


这2种解法都是我借鉴人家的,自己写不出来,看人家的思路也要想好久好久, 每次看到别人写递归我就觉得自己是个傻子。。 哈哈 也有这种感觉,不过理解还是勉强可以理解,只是自己抽象不出来这种思想,菜是原罪,不知道小伙伴们,想的清楚不, 下次先把简单的题刷完先。

相关文章
|
3月前
LeetCode第二十四题(两两交换链表中的节点)
这篇文章介绍了LeetCode第24题的解法,即如何通过使用三个指针(preNode, curNode, curNextNode)来两两交换链表中的节点,并提供了详细的代码实现。
30 0
LeetCode第二十四题(两两交换链表中的节点)
|
3月前
Leetcode第十九题(删除链表的倒数第N个节点)
LeetCode第19题要求删除链表的倒数第N个节点,可以通过快慢指针法在一次遍历中实现。
48 0
Leetcode第十九题(删除链表的倒数第N个节点)
05_删除链表的倒数第N个节点
05_删除链表的倒数第N个节点
|
3月前
(剑指offer)18、删除链表的节点—22、链表中倒数第K个节点—25、合并两个排序的链表—52、两个链表的第一个公共节点(2021.12.07)
(剑指offer)18、删除链表的节点—22、链表中倒数第K个节点—25、合并两个排序的链表—52、两个链表的第一个公共节点(2021.12.07)
57 0
|
5月前
|
算法
LeetCode第24题两两交换链表中的节点
这篇文章介绍了LeetCode第24题"两两交换链表中的节点"的解题方法,通过使用虚拟节点和前驱节点技巧,实现了链表中相邻节点的交换。
LeetCode第24题两两交换链表中的节点
04_两两交换链表中的节点
04_两两交换链表中的节点
|
7月前
|
存储 SQL 算法
LeetCode力扣第114题:多种算法实现 将二叉树展开为链表
LeetCode力扣第114题:多种算法实现 将二叉树展开为链表
|
7月前
|
存储 SQL 算法
LeetCode 题目 86:分隔链表
LeetCode 题目 86:分隔链表
|
7月前
|
存储 算法 Java
【经典算法】Leetcode 141. 环形链表(Java/C/Python3实现含注释说明,Easy)
【经典算法】Leetcode 141. 环形链表(Java/C/Python3实现含注释说明,Easy)
66 2
|
8月前
<数据结构>五道LeetCode链表题分析.环形链表,反转链表,合并链表,找中间节点.
<数据结构>五道LeetCode链表题分析.环形链表,反转链表,合并链表,找中间节点
76 1

热门文章

最新文章