当前位置: 首页 > news >正文

链表的面试题2反转单链表

 

目录

       反转链表

迭代

递归


好,我们接着来看第二题

反转链表

老规矩,放上链接。

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

这道题和上一道的删除特定值的题目有什么区别呢?能不能用上一篇文章讲到的五种办法都放到这里来?好像是可以的。

迭代

我们先来看迭代,上一篇我们已经知道了,迭代是不停的去执行语句。那么这里我们需要迭代的是什么呢?那我们是不是就是要把后一个节点的指针域指向前一个结点?但是这样可行吗?,那会出现什么问题?

诶,就是会找不到下一个节点。但是这里还有一个细节,那第一个节点的指针域呢?需要我们管吗?这当然是需要的。我们要知道前一个节点在我们逆置以后,那就变成尾巴节点了。它的指针域可是要为空的。所以我们在用迭代的时候要先存储前一个节点的指针域再存储后一个节点的指针。这样就可以了

struct ListNode* reverseList(struct ListNode* head) {struct ListNode* prev = NULL;struct ListNode* curr = head;while (curr) {struct ListNode* next = curr->next;curr->next = prev;prev = curr;curr = next;}return prev;
}

代码贴在这里,我们再看递归的方法:

递归

递归和迭代思想类似,也算是很好理解的方式,但是递归有一个点需要我们注意。递归的时候的语句需要让我们的第一个节点的指针域为空,不然就会形成环。

当然我们在递归的内部是动不了手段的。我们需要的是在断言的条件上加上返回的条件。

struct ListNode* reverseList(struct ListNode* head) {if (head == NULL || head->next == NULL) {return head;}struct ListNode* newHead = reverseList(head->next);head->next->next = head;head->next = NULL;return newHead;
}

这样,我们的整个逻辑就完整了。

这里我们在想一种方法,双指针能不能做?双指针在后面解决很多问题的时候不可谓不是利器啊。

既然如此,那我们为什么不用。但是仔细想想,双指针在实际运行的过程中,不就和我们的迭代重合了?我迭代重新创建两个变量 不就代表了我的双指针的作用吗?

所以我其实很喜欢给大家我对于这些简单题的见解。因为越做,一道道题都慢慢想,你会发现自己越来越有学习编程的信心,编程难就是难在去钻研然后融合成自己的东西。

时至今日,我自己写的博客我自己还是一直在更改,一直在复习,每次都有新的见解。

加油,与诸君共勉!

如果你觉得对你有帮助,可以点赞关注加收藏,感谢您的阅读,我们下一篇文章再见。

一步步来,总会学会的,首先要懂思路,才能有东西写。

http://www.xdnf.cn/news/302491.html

相关文章:

  • 第三章:langchain加载word文档构建RAG检索教程(基于FAISS库为例)
  • 5.6 react组件化开发基础
  • Elasticsearch知识汇总之ElasticSearch部署
  • conda 环境克隆
  • ϵ-prediction和z0-prediction是什么意思
  • 关于EIDE中debug的使用问题
  • 如何打造一个高并发系统?
  • linux redis 设置密码以及redis拓展
  • ROS2:话题通信CPP语法速记
  • 从零开始学习人工智能(Python高级教程)Day6-Python3 正则表达式
  • c++学习合集(2025-4-29)
  • setup 函数在 Vue 3 中的作用是什么?什么时候会执行
  • ASP.NET Core 中间件
  • git flow
  • 线性回归有截距
  • 电子电器架构 --- 网关ECU中采用多CPU解决方案来实现网关功能
  • 《算法导论(第4版)》阅读笔记:p9-p9
  • NestJS 的核心构建块有哪些?请简要描述它们的作用(例如,Modules, Controllers, Providers)
  • vue3 computed方法使用详细讲解
  • LeetCode 790 多米诺和托米诺平铺 题解
  • 深入解析 Linux/Unix 通信机制:从原理到观测实践
  • 第四章 Java基础-判断和循环
  • I2C总线驱动开发:MPU6050应用
  • 牛客——暴力、技巧、字符与数组的使用(强强联合、字符数量)
  • [三分钟]性能测试工具JMeter入门: 下载安装JMeter并设置中文;JMeter基本使用流程
  • Linux(十四)进程间通信(IPC),管道
  • leetcode0542. 01 矩阵-medium
  • 第八章,STP(生成树协议)
  • [论文阅读]Deep Cross Network for Ad Click Predictions
  • C# 使用SunnyUI控件 (VS 2019)