【LeetCode-中等题】24. 两两交换链表中的节点

文章目录

题目

方法一:递归

图解:

java 复制代码
				==详细版==
public ListNode swapPairs(ListNode head) {
        /*
        递归法:
        宗旨就是紧紧抓住原来的函数究竟返回的是什么?作用是什么即可
        其余的细枝末节不要细究,编译器会帮我们自动完成
         */
        // base case
        if (head == null || head.next == null) return head;
        
        // swapPairs(ListNode head) 的意义就是两两翻转链表中的节点+返回翻转后的新的头结点
        // 我们知道翻转后新的头结点必然是第二个节点
        // 举例子:1->2->3->4 翻转后:2->1->4->3
        ListNode newHead = head.next; // 2
        // 此时tmpHead为:4->3
        ListNode tmpHead = swapPairs(newHead.next);
        // 而前面的还粘连着:1->2->(3)  4->3
        // 此时再让1->4 此时链表为:2->(3) 1->4->3
        head.next = tmpHead;
        // 再将2指向1即可 此时链表为:2->1->4->3 已经完成翻转
        newHead.next = head;
        // 返回新的头结点
        return newHead;
    }


				==简洁版==

    public ListNode swapPairs(ListNode head) {

       if (head == null || head.next == null) {
                  return head;
        }
        ListNode newnode = head.next;
        head.next = swapPairs(newnode.next);
        newnode.next = head;
        return newnode;
       
    }

方法二:三指针迭代

思路:

  1. 设置一个哑结点,作为第一次交换的落脚点
  2. 设置落脚点往后两个节点
  3. 执行交换,并且让后面的那个节点指向下一次交换的左节点
  4. 最后更新落脚点,进行下次循环,
  5. 一旦temp.next.next 或者 temp.next 为null,说明落脚点后面的节点不满足两两交换的条件
java 复制代码
public ListNode swapPairs(ListNode head) {

    //    造哑结点给begin腾位置
      ListNode newHead  = new ListNode(0,head);
    //定义头结点
     ListNode  begin = newHead;
      while(begin.next != null && begin.next.next != null){
          ListNode left = begin.next;
          ListNode right =  begin.next.next;
          begin.next = right;
          left.next = right.next;
          right.next = left;
          begin = left;
      }
      return newHead.next;

    }
相关推荐
kobesdu6 小时前
人形机器人SLAM:技术挑战、算法综述与开源方案
算法·机器人·人形机器人
椰羊~王小美7 小时前
随机数概念及算法
算法
阿Y加油吧8 小时前
算法实战笔记:LeetCode 169 多数元素 & 75 颜色分类
笔记·算法·leetcode
不要秃头的小孩8 小时前
力扣刷题——509. 斐波那契数
python·算法·leetcode·动态规划
We་ct9 小时前
LeetCode 120. 三角形最小路径和:动态规划详解
前端·javascript·算法·leetcode·typescript·动态规划
py有趣9 小时前
力扣热门100题之和为K的子数组
数据结构·算法·leetcode
hipolymers9 小时前
C语言怎么样?难学吗?
c语言·数据结构·学习·算法·编程
海清河晏11111 小时前
数据结构 | 双循环链表
数据结构·链表
workflower11 小时前
机器人应用-楼宇室内巡逻
大数据·人工智能·算法·microsoft·机器人·动态规划·享元模式