24. 两两交换链表中的节点 -- 力扣 --JAVA

简介: 给你一个链表,两两交换其中相邻的节点,并返回交换后链表的头节点。你必须在不修改节点内部的值的情况下完成本题(即,只能进行节点交换)。

 题目

给你一个链表,两两交换其中相邻的节点,并返回交换后链表的头节点。你必须在不修改节点内部的值的情况下完成本题(即,只能进行节点交换)。

解题思路

    1. 排除无法交换的情况,即:当前节点为空或当前节点无下一个节点;
    2. 获取当前节点的下一个节点,让当前节点的下一个节点指向下下个节点;
    3. 下一个节点指向当前节点;

    代码展示

    class Solution {
        public ListNode swapPairs(ListNode head) {
            if(head == null || head.next == null){
                return head;
            }
            ListNode res = head.next;
            head.next = swapPairs(res.next);
            res.next = head;
            return res;
        }
    }

    image.gif


    目录
    相关文章
    |
    7天前
    |
    索引
    【力扣刷题】两数求和、移动零、相交链表、反转链表
    【力扣刷题】两数求和、移动零、相交链表、反转链表
    15 2
    【力扣刷题】两数求和、移动零、相交链表、反转链表
    |
    2天前
    |
    搜索推荐 算法 Java
    JAVA中的交换类排序算法详解
    JAVA中的交换类排序算法详解
    8 1
    |
    6天前
    题目----力扣--回文链表
    题目----力扣--回文链表
    12 0
    |
    6天前
    题目----力扣--合并两个有序链表
    题目----力扣--合并两个有序链表
    10 0
    |
    6天前
    题目----力扣--反转链表
    题目----力扣--反转链表
    14 0
    |
    6天前
    题目----力扣--链表的中间结点
    题目----力扣--链表的中间结点
    6 0
    |
    6天前
    题目----力扣--移除链表元素
    题目----力扣--移除链表元素
    12 1
    |
    7天前
    |
    索引
    【力扣刷题】删除链表的倒数第 N 个结点、两两交换链表中的节点、随机链表的复制
    【力扣刷题】删除链表的倒数第 N 个结点、两两交换链表中的节点、随机链表的复制
    13 0
    |
    7天前
    |
    存储 算法 索引
    【力扣刷题】只出现一次的数字、多数元素、环形链表 II、两数相加
    【力扣刷题】只出现一次的数字、多数元素、环形链表 II、两数相加
    18 1
    |
    7天前
    |
    索引
    【力扣刷题】回文链表、环形链表、合并两个有序链表
    【力扣刷题】回文链表、环形链表、合并两个有序链表
    13 0