C++算法练习-day9——24.两两交换链表中的节点

题目来源:. - 力扣(LeetCode)

题目思路分析

题目 :给定一个单链表的头节点 head,请你编写一个函数,将链表中的节点成对交换,返回交换后的链表头节点。

思路

  1. 递归法
    • 终止条件:如果链表为空或只有一个节点,直接返回该节点。
    • 递归步骤
      • 设定一个新的头节点 newhead 为当前头节点的下一个节点(即要交换的第二个节点)。
      • 递归调用 swapPairs 函数,传入 newhead->next(即当前要处理的对之后的链表部分),并将结果赋值给当前头节点的 next
      • newheadnext 指向当前头节点,完成这一对节点的交换。
      • 返回新的头节点 newhead

代码:

复制代码
/**  
 * Definition for singly-linked list.  
 * struct ListNode {  
 *     int val;  
 *     ListNode *next;  
 *     ListNode() : val(0), next(nullptr) {}  
 *     ListNode(int x) : val(x), next(nullptr) {}  
 *     ListNode(int x, ListNode *next) : val(x), next(next) {}  
 * };  
 */  
class Solution {  
public:  
    ListNode* swapPairs(ListNode* head) {  
        // 如果链表为空或只有一个节点,直接返回该节点  
        if(head==NULL || head->next==NULL){  
            return head;  
        }  
          
        // newhead 是当前要交换的第二个节点,也就是新链表的头节点  
        ListNode* newhead=head->next;  
          
        // 递归调用 swapPairs 函数,传入 newhead->next,即当前要处理的对之后的链表部分  
        // 将结果赋值给当前头节点的 next,完成递归链表的构建  
        head->next=swapPairs(newhead->next);  
          
        // 将 newhead 的 next 指向当前头节点,完成这一对节点的交换  
        newhead->next=head;  
          
        // 返回新的头节点 newhead  
        return newhead;  
    }  
};

知识点摘要

  1. 链表基础
    • 链表是一种常见的数据结构,由一系列节点组成,每个节点包含数据部分和指向下一个节点的指针。
    • 单链表是指每个节点只有一个指向下一个节点的指针。
  2. 递归
    • 递归是一种解决问题的方法,其中函数直接或间接地调用自身。
    • 递归函数通常包含一个或多个基准条件,用于终止递归调用。
  3. 链表节点交换
    • 链表节点交换通常涉及调整节点间的指针,而不是数据值本身。
    • 在本问题中,通过调整指针实现节点对的交换。

通过这道题目,我们学会了如何使用递归方法解决链表节点成对交换的问题。递归方法虽然简洁,但也需要仔细考虑基准条件和递归步骤,以避免陷入无限递归或导致内存泄漏。此外,对链表操作的理解也是解决此类问题的关键,特别是节点指针的调整。通过实践,我们可以更好地掌握递归和链表操作的相关知识,为更复杂的问题打下坚实的基础。

相关推荐
feiyangqingyun18 分钟前
Qt项目作品在苹果macos上编译运行效果/视频监控系统/物联网平台等
开发语言·qt·macos
你不是我我1 小时前
【Java 开发日记】我们来说一说 Redisson 的原理
java·开发语言
kk”1 小时前
C++ stack 和 queue
开发语言·c++
Matlab仿真实验室1 小时前
基于Matlab实现双目图计算深度图
开发语言·数码相机·matlab·双目图计算深度图
给大佬递杯卡布奇诺1 小时前
FFmpeg 基本API avcodec_send_packet函数内部调用流程分析
c++·ffmpeg·音视频
QT 小鲜肉1 小时前
【数据结构与算法基础】05. 栈详解(C++ 实战)
开发语言·数据结构·c++·笔记·学习·算法·学习方法
lingran__1 小时前
算法沉淀第七天(AtCoder Beginner Contest 428 和 小训练赛)
c++·算法
2401_840105202 小时前
P1049 装箱问题 题解(四种方法)附DP和DFS的对比
c++·算法·深度优先·动态规划
老K的Java兵器库2 小时前
Collections 工具类 15 个常用方法源码:sort、binarySearch、reverse、shuffle、unmodifiableXxx
java·开发语言·哈希算法
武子康2 小时前
Java-153 深入浅出 MongoDB 全面的适用场景分析与选型指南 场景应用指南
java·开发语言·数据库·mongodb·性能优化·系统架构·nosql