数据结构-单链表的反转

一直在路上

目录

前言

本篇文章介绍反转单链表的三种方法,分别为普通方法、头插法、递归法。

一、普通方法

普通方法是从第一个结点开始反转,然后反转剩余的结点。

普通方法需要保存当前结点的前驱和后继,如果当前结点为第一个结点,则前驱设置为NULL

过程如下

图1.1 普通方法反转过程

具体代码如下

c 复制代码
//常规方法反转
struct ListNode* reverseList_nomal(struct ListNode* head)
{
    struct ListNode* cur = head;
    struct ListNode* pre = NULL;	//前驱
    struct ListNode* post = NULL;	//后继

    while(cur != NULL)
    {
        post = cur->next;	//保存后继,保证反转后任然可以找到下一个结点
        cur->next = pre;	//反转
        pre = cur;			//将当前结点保存为下一个结点的前驱
        cur =post;			//将下一个结点作为待反转结点
    }
    return pre;				//将最后一个反转结点作为新的head
}

二、头插法

头插法是将第二个结点及后面的结点一直往第一个结点的前面插入

头插法一般使用一个辅助结点作为第一个结点的前驱

过程如下

图2.1 头插法反转过程

具体代码如下

c 复制代码
//利用头插法反转
struct ListNode* reverseList_headInsert(struct ListNode* head)
{
    //创建一个辅助结点
    struct ListNode* dummyNode = (struct ListNode*)malloc(sizeof(struct ListNode));
    dummyNode->val = -1;
    dummyNode->next = head;


    struct ListNode* curr = dummyNode->next;
    struct ListNode* next = NULL;
	
    while(curr->next != NULL)
    {
        next = curr->next;
        curr->next = next->next;
        next->next = dummyNode->next;
        dummyNode->next = next;

    }
    free(dummyNode);    
    return next;
}

三、递归法

递归方法首先明确的是,即使递归到最后一层,各个结点之间的联系还存在

理解递归的最好方法是,选择一层进行研究,当前层需要做什么,需要返回什么

过程如下

图3.1 递归法反转过程

具体代码如下

c 复制代码
struct ListNode* reverseList_recursion(struct ListNode* head) {
    if(head == NULL || head->next == NULL)
    {
        return head;
    }
	
	//newHead始终指向尾结点
    struct ListNode* newHead = reverseList_recursion(head->next);
    //head->next 相当于未反转前的后继
    //head->next 即当前结点的后继
    //将后继结点的指针域指向当前结点完成反转
    head->next->next = head;
    //将当前结点的指针域断开,否则出现回环
    //回环的意思是当前结点的指针域指向了后继结点,后继结点的指针域指向了当前结点
    head->next =NULL;
    return newHead;
}

总结

第一次用ppt做关于数据结构的过程图,很多地方做的不到位,希望能够继续改进!

相关推荐
小许学java3 小时前
数据结构-ArrayList与顺序表
java·数据结构·顺序表·arraylist·线性表
程序员莫小特6 小时前
老题新解|大整数加法
数据结构·c++·算法
小刘max7 小时前
深入理解队列(Queue):从原理到实践的完整指南
数据结构
蒙奇D索大8 小时前
【数据结构】考研数据结构核心考点:二叉排序树(BST)全方位详解与代码实现
数据结构·笔记·学习·考研·算法·改行学it
洲覆8 小时前
C++ 模板、泛型与 auto 关键字
开发语言·数据结构·c++
MoRanzhi12038 小时前
15. Pandas 综合实战案例(零售数据分析)
数据结构·python·数据挖掘·数据分析·pandas·matplotlib·零售
WIN赢10 小时前
【二叉树的递归算法与层序遍历算法】
数据结构
Zzzzmo_10 小时前
【Java】杨辉三角、洗牌算法
java·数据结构·算法
岑梓铭12 小时前
《考研408数据结构》第四章(串和串的算法)复习笔记
数据结构·笔记·考研·算法
胖咕噜的稞达鸭13 小时前
缝合怪deque如何综合list和vector实现及仿函数模板如何优化priority_queue实现
数据结构·c++·算法·链表·list