链表中两两交换结点(力扣24)


文章目录


题目

Problem: 24. 两两交换链表中的节点

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

示例:

输入: 1->2->3->4

输出: 2->1->4->3

注意:

  • 你的算法只能使用常数的额外空间。
  • 你不能只是单纯的改变节点内部的值,而是需要实际的进行节点交换。

题解

一、思路

  • 建立虚拟头结点可以不用单独考虑头结点的特殊情况:
java 复制代码
ListNode dummy = new ListNode(-1);
dummy.next = head;
  • 设置两个临时变量存储在交换时会丢失的结点,分别存储下一个结点的前一个和后一个结点

在循环时想清楚终止条件应该为什么:当后面没有结点时,不用再交换位置,在剩一个结点时,也不用交换位置,因为都不满足两个结点的个数不用进行交换,所以终止条件为:
while(cur.next != null&&cur.next.next!=null)

二、解题方法

首先创建虚拟头结点dummy,它的下一个结点指向头结点,按照图中步骤一二三,先指向2,此时结点1、3都由firstNode和secondNode保存,移动cur指针到要交换的元素前一个的位置,这样才能对交换的元素进行操作,循环结束后,记得返回虚拟头结点的下一个结点才是真正的头结点

三、Code

java 复制代码
/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode() {}
 *     ListNode(int val) { this.val = val; }
 *     ListNode(int val, ListNode next) { this.val = val; this.next = next; }
 * }
 */
class Solution {
    public ListNode swapPairs(ListNode head) {
        ListNode dummy = new ListNode(-1);
        dummy.next = head;
        ListNode cur = dummy;
        ListNode firstNode;
        ListNode secondNode;

        while(cur.next != null&&cur.next.next!=null){
            firstNode = cur.next;
            secondNode = cur.next.next.next;
            cur.next = cur.next.next; //步骤一
            cur.next.next = firstNode;//步骤二
            cur.next.next.next = secondNode;//步骤三
            cur = cur.next.next;
        }
        return dummy.next;
    }
}

总结

这就是对力扣第24题的解题思路和代码实现,需要注意的时如果想对当前元素进行操作,必须要让指针指在前一个元素才能.next操作的了当前元素。希望本文对你理解和解决这道题有所帮助!

相关推荐
加农炮手Jinx4 小时前
LeetCode 72. Edit Distance 题解
算法·leetcode·力扣
_深海凉_4 小时前
LeetCode热题100-打家劫舍
算法·leetcode·职场和发展
qeen876 小时前
【数据结构】树的基本概念及存储
c语言·数据结构·c++·学习·
一江寒逸6 小时前
数据结构与算法之美:串(字符串)——从基础操作到KMP模式匹配,吃透面试最高频的字符串考点
数据结构·面试·职场和发展
hi_ro_a7 小时前
C++ 哈希表封装 unordered_map /unordered_set
数据结构·c++·算法·哈希算法
Jasmine_llq11 小时前
《B4447 [GESP202512 二级] 环保能量球》
数据结构·算法·数学公式计算(核心)·整数除法算法·多组数据循环处理·输入输出算法·简单模拟算法
菜鸟丁小真11 小时前
LeetCode hot100 -73.矩阵置零
数据结构·leetcode·矩阵·知识点总结
We་ct12 小时前
LeetCode 64. 最小路径和:动态规划入门实战
开发语言·前端·算法·leetcode·typescript·动态规划
꧁细听勿语情꧂12 小时前
向下调整算法,top - k 问题,链式结构二叉树,前中后序遍历
c语言·开发语言·数据结构·算法
踩坑记录13 小时前
leetcode hot100 169. 多数元素 easy 技巧 摩尔投票
leetcode