0

0

如何在不修改节点值的前提下两两交换链表节点

心靈之曲

心靈之曲

发布时间:2026-02-25 11:12:13

|

536人浏览过

|

来源于php中文网

原创

如何在不修改节点值的前提下两两交换链表节点

本文详解链表两两交换相邻节点的实现要点,重点解决新手常犯的「头节点未更新」问题,并提供健壮、可读性强的迭代解法及可视化分析。

本文详解链表两两交换相邻节点的实现要点,重点解决新手常犯的「头节点未更新」问题,并提供健壮、可读性强的迭代解法及可视化分析。

在链表操作中,“两两交换相邻节点”(Swap Nodes in Pairs)是一道经典基础题,要求仅通过调整指针完成交换,严禁修改节点数据值。许多初学者(如题中代码所示)能正确重连节点关系,却忽略了最关键的一步:更新链表头节点(head)引用——这直接导致返回结果丢失首节点,出现 [1,4,3] 而非预期 [2,1,4,3] 的错误。

? 核心问题定位:头节点未重定向

原代码逻辑本身对 next 指针的调整基本正确,但存在一个根本性疏漏:
✅ 成功将 2→1→4→3 的链式结构构建完成;
❌ 却仍让 head 指向原第一个节点(值为 1),而新链表真正的起点是原第二个节点(值为 2)。

如下图所示,交换完成后若不更新 head,遍历时将从 1 开始,跳过前置的 2:

初始状态:
head
 ↓
[1] → [2] → [3] → [4] → null

交换后(指针已重连):
head
 ↓
[1]    [2] → [1]    [3] → [4] → null
  └─────↑        └────↑
        └────────────┘
(形成环与断裂,实际结构为:[2]→[1]→[4]→[3]→null)

但 head 仍指向 [1] → 因此遍历得 [1]→[4]→[3] ❌

因此,必须在进入主循环前,将 head 显式指向原 head.next

第三波网上书店源码
第三波网上书店源码

网络购物已经随着Ineternet的飞速发展而得到越来越多应用。为了提高交易效率,节省人们的宝贵时间,我们开发了这套稳定可靠、操作方便、安全有效的时尚购书系统,它主要分为前台和后台两大模块:(前台)使用了站点地图,显示您所在网站的位置。首页图书列表显示,用户登陆,用户注 册,列出图书详细,购物车功能,以及结算等。(后台)图书、用户的添加,删除,修改等操作,查看客户的订单及修改 该项目采用三层结构开

下载
public ListNode swapPairs(ListNode head) {
    // 边界处理:空链表或单节点无需交换
    if (head == null || head.next == null) {
        return head;
    }

    // ✅ 关键修正:更新头节点为第二个节点
    ListNode newHead = head.next;

    ListNode prev = null;        // 指向前一对交换节点的尾部(用于连接下一对)
    ListNode first = head;       // 当前对的第一个节点
    ListNode second = head.next; // 当前对的第二个节点

    while (first != null && second != null) {
        // 保存下一对的第一个节点(即 second.next)
        ListNode nextFirst = second.next;

        // 执行交换:second → first → nextFirst
        if (prev != null) {
            prev.next = second; // 连接上一对与当前对
        }
        first.next = nextFirst;
        second.next = first;

        // 更新指针,准备处理下一对
        prev = first;
        first = nextFirst;
        second = (first != null) ? first.next : null;
    }

    return newHead;
}

? 注意:我们返回 newHead(即原始 head.next),而非原 head,确保入口正确。

✅ 正确性验证(以 [1,2,3,4] 为例)

步骤 prev first second nextFirst 链表状态(从 newHead 开始)
初始 null [1] [2] [3] head → [2]→[1]→[3]→[4]
交换后 [1] [3] [4] null → [2]→[1]→[4]→[3]
循环结束 ✅ 返回 [2,1,4,3]

⚠️ 关键注意事项

  • 不要复用 head 变量:head 是入参引用,直接赋值 head = head.next 在 Java 中虽可工作,但语义不清;推荐使用 newHead 明确表达意图。
  • 空指针防护:每次访问 second.next 前需确认 second != null;进入循环条件应为 first != null && second != null。
  • 边界兼容性:该解法天然支持奇数长度链表(如 [1,2,3] → [2,1,3]),末尾单节点自动保留。
  • 空间复杂度:仅使用常数额外变量,O(1);时间复杂度 O(n),遍历一次。

✅ 总结

两两交换链表节点的本质是局部指针重定向 + 全局头节点校准。初学者易陷入“只调内部、忽略入口”的思维定式。牢记:
? 交换改变的是结构,而 head 是结构的唯一入口标识
? 任何使首节点发生位移的操作,都必须同步更新 head(或其等价返回值);
? 借助草图追踪指针变化,是调试链表题最高效的方法。

掌握此模式后,可自然延展至更复杂的链表翻转(如 K 组翻转)、环检测等进阶问题。

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

智谱清言 - 免费全能的AI助手
智谱清言 - 免费全能的AI助手

智谱清言 - 免费全能的AI助手

相关专题

更多
c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

246

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

886

2024.03.01

空指针异常处理
空指针异常处理

本专题整合了空指针异常解决方法,阅读专题下面的文章了解更多详细内容。

23

2025.11.16

batoto漫画官网入口与网页版访问指南
batoto漫画官网入口与网页版访问指南

本专题系统整理batoto漫画官方网站最新可用入口,涵盖最新官网地址、网页版登录页面及防走失访问方式说明,帮助用户快速找到batoto漫画官方平台,稳定在线阅读各类漫画内容。

23

2026.02.25

Steam官网正版入口与注册登录指南_新手快速进入游戏平台方法
Steam官网正版入口与注册登录指南_新手快速进入游戏平台方法

本专题系统整理Steam官网最新可用入口,涵盖网页版登录地址、新用户注册流程、账号登录方法及官方游戏商店访问说明,帮助新手玩家快速进入Steam平台,完成注册登录并管理个人游戏库。

1

2026.02.25

TypeScript全栈项目架构与接口规范设计
TypeScript全栈项目架构与接口规范设计

本专题面向全栈开发者,系统讲解基于 TypeScript 构建前后端统一技术栈的工程化实践。内容涵盖项目分层设计、接口协议规范、类型共享机制、错误码体系设计、接口自动化生成与文档维护方案。通过完整项目示例,帮助开发者构建结构清晰、类型安全、易维护的现代全栈应用架构。

0

2026.02.25

Python数据处理流水线与ETL工程实战
Python数据处理流水线与ETL工程实战

本专题聚焦 Python 在数据工程场景下的实际应用,系统讲解 ETL 流程设计、数据抽取与清洗、批处理与增量处理方案,以及数据质量校验与异常处理机制。通过构建完整的数据处理流水线案例,帮助开发者掌握数据工程中的性能优化思路与工程化规范,为后续数据分析与机器学习提供稳定可靠的数据基础。

0

2026.02.25

Java领域驱动设计(DDD)与复杂业务建模实战
Java领域驱动设计(DDD)与复杂业务建模实战

本专题围绕 Java 在复杂业务系统中的建模与架构设计展开,深入讲解领域驱动设计(DDD)的核心思想与落地实践。内容涵盖领域划分、聚合根设计、限界上下文、领域事件、贫血模型与充血模型对比,并结合实际业务案例,讲解如何在 Spring 体系中实现可演进的领域模型架构,帮助开发者应对复杂业务带来的系统演化挑战。

0

2026.02.25

Golang 生态工具与框架:扩展开发能力
Golang 生态工具与框架:扩展开发能力

《Golang 生态工具与框架》系统梳理 Go 语言在实际工程中的主流工具链与框架选型思路,涵盖 Web 框架、RPC 通信、依赖管理、测试工具、代码生成与项目结构设计等内容。通过真实项目场景解析不同工具的适用边界与组合方式,帮助开发者构建高效、可维护的 Go 工程体系,并提升团队协作与交付效率。

18

2026.02.24

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号