leetcode206反转链表|详细算法讲解学习

题目 

https://leetcode.cn/problems/reverse-linked-list/

 这道题对于刚开始学习数据结构和算法的人来说有点难,是入门的重要典型题目;但等数据结构入门之后,这就会是一道非常简单的题目了。

算法一(算法正确但超出时间限制)

/*** 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:int lengthLink(ListNode* head){ListNode* p=head;int len=0;while(p){if(p){len++;p=p->next;}else{return len;}            }return len;}ListNode* reverseList(ListNode* head) {if(head==nullptr)return head;int len=lengthLink(head);ListNode*p=head;for(int i=1;i<len-1;i++){p=p->next;}ListNode* res=head;for(int i=1;i<len;i++){res=res->next;}ListNode* q=p->next;ListNode* L=new ListNode();L->next=head;while(len!=2){ListNode* pre=L;q->next=p;q=p;for(int i=1;i<len-1;i++){pre=pre->next;}p=pre;len--;}p->next=nullptr;delete L;return res;}
};

 逻辑思路

    int lengthLink(ListNode* head){ListNode* p=head;int len=0;while(p){if(p){len++;p=p->next;}else{return len;}            }return -1;}

 这个函数是用来计算链表的长度的。将head传入,会返回链表的长度。

求出链表的长度len,之后len会变化,用来表示原链表中未反转的部分的节点的长度

下面是算法主体的逻辑思路:

以下面的链表为例:

使指针p指向倒数第二个节点,使q指向p的下一个节点,也就是倒数第一个节点。

q->next=p;

q=p;

q指向的节点的指针域指向p指向的节点

指针q指到p指向的节点上

但是这个时候,没法控制p前面的那个节点,所以就需要一个指针pre。

申请一个空节点L作为头结点指向head,使pre刚开始的时候指向L,每次循环遍历到p之前的那个节点。假设p指向倒数第i个节点,pre就循环遍历指向第i+1个节点。

pre指向了p的前一个节点后,让p指向pre指向的节点。然后继续逆置下一个链表的箭头的方向。

但是,反转链表后,怎么返回这个链表呢?要在还没开始进行链表反转时,使用一个指针res指向尾节点。等最后箭头方向都修改了之后,返回res即可。 

代码如下:

    ListNode* reverseList(ListNode* head) {if(head==nullptr)return head;int len=lengthLink(head);ListNode*p=head;for(int i=1;i<len-1;i++){p=p->next;}ListNode* res=head;for(int i=1;i<len;i++){res=res->next;}ListNode* q=p->next;ListNode* L=new ListNode();L->next=head;while(len!=2){ListNode* pre=L;q->next=p;q=p;for(int i=1;i<len-1;i++){pre=pre->next;}p=pre;len--;}p->next=nullptr;delete L;return res;}

算法二  双指针

首先使用cur指针指向head节点。

在反转链表的过程中,需要指向当前节点的前一个节点 ,用来改变链表节点的指向。

使用指针pre定义在cur的前面

在初始化的时候:

cur=head;

pre=null;

将pre初始为Null,是为了将第一个节点改变指向,指向为Null。

代码如下:

/*** 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* reverseList(ListNode* head) {if(head==nullptr||head->next==nullptr)return head;ListNode* cur=head;ListNode* pre=nullptr;while(cur!=nullptr){ListNode* temp=cur->next;cur->next=pre;pre=cur;cur=temp;}return pre;}
};

方法二和方法一类似,pre和cur类似于p和q,方法一中的pre的作用是为了从后向前执行任务,方法二中的temp的作用是为了从前往后执行任务。

方法三  递归

class Solution {
public:ListNode* reverseList(ListNode* head) {if(head==nullptr||head->next==nullptr)return head;ListNode* newHead = reverseList(head->next);head->next->next = head;head->next = nullptr;return newHead;}
};

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SQL在云计算中的新角色:重新定义数据分析

文章目录 1. 云计算与数据分析的融合2. SQL在云计算中的新角色3. 分布式SQL查询引擎4. SQL-on-Hadoop解决方案5. SQL与其他数据分析工具的集成6. 实时数据分析与SQL7. SQL在云数据仓库中的角色8. 安全性与隐私保护9. SQL的未来展望《SQL数据分析实战&#xff08;第2版&#xff…

python创建udf函数步骤

一、目标 实现一个函数&#xff0c;传入两个datetime类型的参数&#xff0c;返回double类型的工作日天数 二、思路 如何计算差值&#xff1f; 如果开始时间和结束时间在同一天&#xff1a;实现同 datediff(end, start, ‘ss’) / 86400.0 如果开始时间和结束时间在不同天&am…

通过docker-compose部署NGINX服务,并使该服务开机自启

要在通过docker-compose部署的NGINX服务实现开机自启&#xff0c;你需要确保Docker守护进程在系统启动时自动运行&#xff0c;并配置docker-compose.yml文件以在容器中运行NGINX服务。以下是步骤&#xff1a; 确保Docker守护进程开机启动&#xff1a; 在Ubuntu/Debian上&#x…

服务器安装Docker (ubuntu)

前几天因为工作需求&#xff0c;要在服务器上安装Docker&#xff0c;现在把这个过程记录下来 步骤 1&#xff1a;更新软件包索引 打开终端并执行以下命令来更新包索引&#xff1a; sudo apt-get update步骤 2&#xff1a;安装必要的包 安装一些允许apt通过HTTPS使用仓库的包…

HACKTHEBOX通关笔记——mango(退役)

信息收集 端口扫描 ┌──(root㉿kali)-[~] └─# nmap -sC -sV -A -p- --min-rate10000 10.129.229.185 Starting Nmap 7.94SVN ( https://nmap.org ) at 2024-01-31 20:44 EST Warning: 10.129.229.185 giving up on port because retransmission cap hit (10). Nmap scan …

开关电源用什么电感

开关电源用什么电感 电感波形图 我们看图&#xff0c;如下图所示&#xff1a; 图1 电感波形示意图 PWM那张图和inductor那张图&#xff0c;第一张图就是Buck电路图SW引脚的波形&#xff0c;看波形我们知道在t1的时候是vi在t2的时候是0&#xff0c;紧接着电流和电压经过电感以…

【Godot4.2】文件系统自定义控件 - FileSystemTree

FileSystemTree B站【Godot4.2】文件系统自定义节点 - FileSystemTree 概述 在Godot设计编辑器插件或应用程序时&#xff0c;可能需要涉及文件系统的显示&#xff0c;比如文件夹或文件的树形列表。 我们可以用Godot的Tree控件快速书写相应的功能&#xff0c;但是为了复用到…

戴上HAUWEI WATCH GT 4,解锁龙年新玩法

春节将至&#xff0c;华为WATCH GT 4作为一款颜值和实力并存的手表&#xff0c;能为节日增添了不少趣味和便利。无论你是钟情于龙年表盘或定制属于自己的表盘&#xff0c;还是过年用来抢红包或远程操控手机拍全家福等等&#xff0c;它都能成为你的“玩伴”。接下来&#xff0c;…

【新书推荐】7.1 do while语句

本节必须掌握的知识点&#xff1a; 示例二十二 代码分析 汇编解析 ■do while语句其语法形式&#xff1a; do{ 语句块; }while(表达式) ■语法解析&#xff1a; ●执行do循环体内的语句块&#xff1b; ●判断while语句里的表达式&#xff0c;表达式为真继续下次循环&#…

【FPGA开发】Modelsim和Vivado的使用

本篇文章包含的内容 一、FPGA工程文件结构二、Modelsim的使用三、Vivado的使用3.1 建立工程3.2 分析 RTL ANALYSIS3.2.1 .xdc约束&#xff08;Constraints&#xff09;文件的产生 3.3 综合 SYNTHESIS3.4 执行 IMPLEMENTATION3.5 烧录程序3.6 程序固化3.6.1 SPI约束3.6.2 .bin文…

Java线程是怎么实现run方法的执行的呢?【 多线程在JVM中的实现原理剖析】

Java线程是怎么实现run方法的执行的呢&#xff1f;【 多线程在JVM中的实现原理剖析】 查看naive state0 方法JVM_StartThread 方法创建操作系统线程操作系统线程执行 本文转载-极客时间 我们知道Java线程是通过行start()方法来启动的&#xff0c;线程启动后会执行run方法内的代…

服务器安装Docker (centOS)

1. 卸载旧版本的Docker&#xff08;如果有&#xff09; 首先&#xff0c;如果您的系统上安装了旧版本的Docker&#xff0c;需要将其卸载。Docker的旧版本称为docker或docker-engine。使用以下命令来卸载旧版本&#xff1a; sudo yum remove docker \ docker-client \ docker-…