数据结构-单链表的反转

news2024/11/26 20:44:22

一直在路上

目录

  • 前言
  • 一、普通方法
  • 二、头插法
  • 三、递归法
  • 总结

前言

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

一、普通方法

普通方法是从第一个结点开始反转,然后反转剩余的结点。
普通方法需要保存当前结点的前驱和后继,如果当前结点为第一个结点,则前驱设置为NULL
过程如下
在这里插入图片描述

图1.1 普通方法反转过程

具体代码如下

//常规方法反转
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 头插法反转过程

具体代码如下

//利用头插法反转
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 递归法反转过程

具体代码如下

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做关于数据结构的过程图,很多地方做的不到位,希望能够继续改进!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2187346.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

DevExpress WinForms v24.1新版亮点:富文本编辑器、电子表格组件功能升级

DevExpress WinForms拥有180组件和UI库,能为Windows Forms平台创建具有影响力的业务解决方案。DevExpress WinForms能完美构建流畅、美观且易于使用的应用程序,无论是Office风格的界面,还是分析处理大批量的业务数据,它都能轻松胜…

自动驾驶-轨迹拼接

在进行自动驾驶的规划之前,要确定当前帧轨迹规划的起点,这个起点常被误认为是当前车辆的位置,即每次以车辆的当前位置进行轨迹规划;其实不是这样的,直观上,这会导致本次次规划的轨迹同上次规划的轨迹之间是…

如何计算服务需要部署多少台机器?

写在前面 遇到流量激增的性能问题,相信绝大多数人的第一反应不是优化代码而是加机器!比如隔壁微博一旦出现爆炸性吃瓜,就会紧急扩机器,防止自己服务被打挂(虽然经常被打挂 这篇文章我们就来讲一下如何 计算出一个服务…

项目配置说明

文章目录 一、下载 vscode 并安装相应扩展1.1 下载 vscode1.2 安装扩展 二、git 项目三、git 提交流程3.1 确定要提交的代码 四、git 拉新流程 一、下载 vscode 并安装相应扩展 1.1 下载 vscode vscode 我已经发群里了,或者自己去官网下载也行 1.2 安装扩展 打开…

四舵轮车辆中的舵轮角度计算

对于四舵轮车辆,或者对角线安装的双舵轮车辆来说,当同时存在线速度与角速度的时候,它的两个轮子的角度值是不一样的,而它的角度值与其当时的瞬心相关(机器人模型与ICR(Instantaneous Center of Rotation))。…

IP6537_C_30W20V--移动设备快充的得力助手,集成 14 种快充协议的降压 SoC

IP6537_C_30W20V是一款集成同步开关的降压转换器、支 持 14 种输出快充协议、支持 Type-C 输出和 USB PD2.0/PD3.0(PPS)协议的 SoC,为车载充电器、 快充适配器、智能排插提供完整的解决方案。 IP6537_C_30W20V支持 USB Type-C 或者 USB A 输出, 5V 输出功…

火语言RPA流程组件介绍--模拟键盘输入

🚩【组件功能】:在浏览器网页中使用键盘操作模拟输入值 配置预览 配置说明 按键间隔(ms) 支持T或# 输入仅支持整型 两次输入按键的间隔,单位毫秒 输入内容 支持T或# 默认FLOW输入项 需要输入的内容 超时时间 支持T或# 输入仅支持整型 输入的超时时…

我们的赞赏码

每一位粉丝的认可,都是我们前进的动力。欢迎为我们点赞、转发和分享,让我们一起传递美好与快乐! 我们真诚地邀请您来赞赏我们,您的认可是我们前进的动力! 赞赏我们只要0.99,让我们一起在CSDN增长知识&…

OpenAI 开发者大会!实时语音功能有API了,GPT-4o支持多模态微调,上下文cache功能上线

家人们!十一假期第1天, OpenAI一年一度的开发者大会又来了惹!今年的开发者大会分成三部分分别在美国、英国、新加坡三个地点举办,刚刚结束的是第一场。 去年的OpenAI开发者大会公布了GPT-4 Turbo和GPTs,今年没有大更新…

【硬件模块】SG90舵机模块

SG90舵机模块实物图 180度舵机:可以控制旋转角度、有角度定位。上电后舵机自动复位到0度,通过一定参数的脉冲信号控制它的角度。 360舵机:不可控制角度,只能控制顺时针旋转、逆时针旋转、停止和调节转速。 如图所示为:…

仅用pygame+python实现植物大战僵尸-----完成比完美更重要

前言 其实这个项目再我上半年就想着做一下的,但是一直拖到现在,我现在深刻的理解到,不要想那么多,先做,因为永远不可能准备好,都是边做边学便准备的,完成比完美更重要;使用python&a…

【YOLO学习】YOLOv2详解

文章目录 1. 概述2. Better2.1 Batch Normalization(批归一化)2.2 High Resolution Classifier(高分辨率分类器)2.3 Convolutional With Anchor Boxes(带有Anchor Boxes的卷积)2.4 Dimension Clusters&…

每日一题|1928. 规定时间内到达终点的最小花费|动态规划、最小路径

本题需要使用动态规划进行解决。 分析: 求解最小值而且每一次的状态是由上一次的状态推导出来的,用动态规划。 难点:dp数组的定义和更新。 1、dp数组的定义 在时刻t,位置i处,此时的花费可以表示为如下的形式&#…

CNN卷积神经网络算法原理

全连接神经网络概述 输入层在左点自外,相应的输出层在右点之外, 这就像一个函数,yf(x),x即输入,f即隐藏层,y即输出,或者是ymodel(x) 全连接神经网络的结构单元 主要是从单元到整体&#xff0c…

杀疯啦!yolov11+strongsort的目标跟踪实现

目录 yolov11介绍——实时端到端物体检测 概述 主要特征 支持的任务和模式 性能指标 总结 strongsort介绍 指标图 系统定位 效果展示 训练与预测 UI设计 界面其他功能展示 完整代码实现UI界面 yolov11介绍——实时端到端物体检测 概述 YOLO11 是 Ultralytics Y…

基于yolov5 无人机检测包含:数据集➕训练好的代码模型训练了300轮 效果看下图 map97%以上

基于yolov5 无人机检测包含:数据集➕训练好的代码模型训练了300轮 效果看下图 map97%以上 基于YOLOv5的无人机检测项目 项目名称 基于YOLOv5的无人机检测 (Drone Detection with YOLOv5) 项目概述 该项目使用YOLOv5模型进行无人机目标检测。数据集包含大量带有标注的无人机…

wsl中安装ubuntu,vscode访问这个ubuntu

WSL1升级为WSL2 wsl --set-default-version 2 wsl --set-version Ubuntu-22.04 2在windows商店中也可以安装ubuntu,在这个ubuntu中windows的c盘在/mnt/c中

国庆刷题(day2)

C语言刷题: C刷题:

数据结构与算法——Java实现 27.双端队列

很多人觉得做一件事付出了10分的努力,却只得到5分的汇报。 其实剩下的五分,是在填补你过往的懒惰。 只有将过往的懒惰填满, 努力才会有正向结果 —— 24.10.3 一、概述 双端队列、队列、栈对比: 队列 一端删除(头&am…

计算机毕业设计 基于Python的个性化旅游线路推荐系统的设计与实现 Python+Django+Vue 前后端分离 附源码 讲解 文档

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点…