《剑指offer》——从尾到头打印链表

首先,拿到题之后,我们还是先从题目入手,只有掌握题干的意思,才能进行接下来的解题操作。

 示例1

输入    :  {1,2,3}
返回值:[3,2,1]

示例2

输入    :{67,0,24,58}

返回值:[58,24,0,67]


解题方法

a)直接遍历法

b)递归思想

c)栈思想


题目解析:

  • 首先,拿到这个题,读过题之后我们会发现题意很简单,就是让我们针对链表中的元素,把它从尾到头输出即可。接下来,我提供给大家三种解题思路。

a)直接遍历法

💨思路:

  1. 我们先开辟一个数组,紧接着我们可以直接对这个链表进行从头节点开始的遍历操作。
  2. 记录下这个链表中的每个节点的值,把相应的值放入我们建立的数组之中。
  3. 最后遍历完毕在反转一下整个数组,返回即可。

代码如下:

class Solution {
public:
    vector<int> printListFromTailToHead(ListNode* head) {
        vector<int>arr;  //开辟的数组用来存放链表中的值
        while(head)
        {
            arr.push_back(head->val); //进行遍历操作,把元素插入数组
            head=head->next;
        }

        reverse(arr.begin(),arr.end());//最后反转数组即可
        return arr;
    }
};

性能分析:

  • 时间复杂度:因为需要直接遍历长度为n的链表的所有的结点,所以时间复杂度为O(n)
  • 空间复杂度:因为我们开辟了一个链表大小数组的用来存放链表结点中的值,因此空间复杂度为O(n)

b)递归思想

首先解答一下什么是递归:

  • 首先,绝大多数问题都可以划分成更小的问题,通过求解这些小问题,将结果合并在一起得到原本问题的答案,其实递归的本质就是函数调用而已。因此,接下来的关键就是通过题意查看是否可以拆分为一个个的子问题。

 

💨思路:

  1. 首先,我们应该明白一点知识点,那就是我们对于链表来说,我们是不能直接通过遍历链表就得到题目所要求的从尾向头输出链表中的结点值。
  2. 所以我们可以对遍历的结点进行一个递归,我们先递归到这个链表的最后面,然后不断向前收集查看结点的权值。

代码如下:

//递归思想
void recursion(ListNode* head,vector<int>&arr)
{
    if(head != NULL)
    {
       recursion(head->next,arr); //如果当前指针不为空,则一直往后进行递归操作
       arr.push_back(head->val);  //遇到尾节点后开始返回,每次返回依次添加一个值进入输出数组
    }
}

class Solution {
public:
    vector<int> printListFromTailToHead(ListNode* head) {
       vector<int>arr;  //还是跟之前一样,开辟一个数组用来存放链表中结点的值

       recursion(head,arr); //递归调用去进行查看
       return arr;
    }
};

性能分析:

  • 时间复杂度:因为需要直接遍历长度为n的链表的所有的结点,所以时间复杂度为O(n)
  • 空间复杂度:因为我们开辟了一个链表大小的组用来存放链表中结点的值,因此空间复杂度为O(n)

c)栈思想

首先认识一下栈

首先,站的基本思想就是先进后出,如果对栈不了解的,可以参考这篇文章 栈的实现 ,它的基本思想满足本题中对链表进行从尾到头输出的条件。

💨思路:

  • 我们可以从头结点开始顺序遍历整个链表,遍历的过程中将链表结点的值依次push到栈中
  • 遍历完之后,再依次弹出栈中的元素,加入到数组中
  • 最后返回数组,即可实现本题所要求的逆序输出

代码如下:

//栈思想

class Solution {
public:
    vector<int> printListFromTailToHead(ListNode* head) {
       vector<int>arr;  //还是跟之前一样,开辟一个数组用来存放链表中结点的值
       stack<int> str;  //定义的栈

       while(head != NULL)
       {
          str.push(head->val); //首先遍历链表,把其中结点的权值全部压入栈中
          head=head->next;
       }

       while(!str.empty())
       {
          //因为要求用数组返回把栈中的所有元素全部尾插到数组中
          arr.push_back(str.top());
          //弹出栈中的元素,即表示逆序输出的结果
          str.pop();                  
       }
       //最后返回数组的内容
       return arr;
    }
};

性能分析:

  • 时间复杂度:不仅需要直接遍历长度为n的链表的所有的结点,其次弹出栈的所有元素又需要O(n),所以时间复杂度为O(n)
  • 空间复杂度:因为我们开辟了一个链表大小的数组用来存放链表中结点的值,其次栈空间最大长度是链表的长度n,因此空间复杂度为O(n)

 


到此,关于本题的讲解便全部结束!!!

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【Python】1分钟就能制作精美的框架图?太棒啦

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录前言一、准备二、基本使用与例子1.初始化与导出2.节点类型3.集群块4.自定义线的颜色与属性总结前言 Diagrams 是一个基于Python绘制云系统架构的模块&#xff0c;它能…

分享10个前端开发者需要掌握的DOM技巧

Web开发不断发展&#xff0c;掌握最新的趋势和最佳实践对每位开发者来说都至关重要。Web开发的最重要方面之一就是使用文档对象模型&#xff08;DOM&#xff09;。在本文中&#xff0c;我们将探讨10个必须掌握的DOM技巧和技巧&#xff0c;配有代码示例&#xff0c;这将帮助您成…

超越辅助:分享一个基于GPT引擎的免费AI工具

最近 ChatGPT 实在火爆,它能够生成文本,能做问答系统,能当翻译,创意写作者,编程辅助。神乎其技,但这些功能仅仅是 ChatGPT 的冰山一角。由于其强大的学习能力和广泛的知识库,ChatGPT 可以在许多其他领域发挥作用,为用户带来便利和价值。 由于环境因素,国内能直接使用…

一文解读基于PaddleSeg的钢筋长度超限监控方案

项目背景 钢铁厂生产钢筋的过程中会存在部分钢筋长度超限的问题&#xff0c;如果不进行处理&#xff0c;容易造成机械臂损伤。因此&#xff0c;需要通过质检流程&#xff0c;筛选出存在长度超限问题的钢筋批次&#xff0c;并进行预警。传统的处理方式是人工核查&#xff0c;该方…

管廊隧道怎么定位人员?分享管廊隧道人员定位系统解决方案

管廊隧道施工的安全不仅关系着施工项目的质量与施工效率&#xff0c;更是关系着国家财产安全以及施工人员和人民群众的生命和财产安全。如何有效加强管廊隧道施工安全管理水平成为管廊隧道项目施工企业管理者最为关注的问题。 管廊隧道施工安全管理痛点难题 1.风险预警难 现场…

ubuntu16.04搭建gitlab

ubuntu16.04搭建gitlab 目录ubuntu16.04搭建gitlab一、在虚拟机ubuntu16.04安装gitlab二、配置gitlab三、使用gitlab四、踩坑记录工作中遇到需要在远端服务器搭建gitlab&#xff0c;耗时4天&#xff0c;踩坑无数&#xff0c;特此开个虚拟机再次搭建一次gitlab并记录供以后参考&…

原油期货是什么?原油期货交易盈利技巧有哪些?

现如今大多数人的手中都不宽裕&#xff0c;都在想方设法的赚钱&#xff0c;那么有没有简单又来钱快的方法呢&#xff1f;答案是&#xff1a;有的&#xff0c;那就是原油期货交易&#xff0c;虽然原油期货交易来钱快&#xff0c;但只要是投资就有一定的风险。投资者想要做好原油…

二叉树练习题(递归展开图详解哦)

全文目录引言单值二叉树题目描述及思路实现二叉树的最大深度题目描述及思路实现翻转二叉树题目描述及思路实现相同的树题目描述及思路实现总结引言 前面我们介绍了二叉树的相关基础知识&#xff0c;并且了解到二叉树的表示有两种结构&#xff1a;顺序结构与链式结构。即&#…

6、springboot快速使用

文章目录1、最佳实践1.1、引入场景依赖1.2、查看自动配置了哪些&#xff08;选做&#xff09;1.3、是否需要修改配置1、修改配置2、自定义加入或者替换组件3、自定义器 XXXXXCustomizer2、开发小技巧2.1、Lombok1、引入坐标2、在IDEA中安装lombok插件&#xff08;新版默认安装&…

USB在虚拟机中不显示以及没有访问权限

USB在虚拟机中不显示以及没有访问权限 不显示可以在虚拟机中点击设置按键选择移除USB设备然后再添加&#xff0c;在右下脚就会显示USB图标&#xff0c;点击链接到主机即可。 无访问权限输入一下命令&#xff1a; sudo chmod 666 /dev/ttyUSB0

建龙转债上市价格预测 - 配了38张道氏,希望不要乱跌

建龙转债基本信息转债名称&#xff1a;建龙转债&#xff0c;评级&#xff1a;AA-&#xff0c;发行规模&#xff1a;7.0亿元。正股名称&#xff1a;建龙微纳&#xff0c;今日收盘价&#xff1a;96.19元&#xff0c;转股价格&#xff1a;123.0元。当前转股价值 转债面值 / 转股价…

springboot+jwt令牌简单登录案例

1. 什么是JWT&#xff1f;JSON Web Token JSON Web Token (JWT)是⼀个开放标准(RFC 7519)&#xff0c;它定义了⼀种紧凑的、⾃包含的⽅式&#xff0c;⽤于 作为JSON对象在各⽅之间安全地传输信息。该信息可以被验证和信任&#xff0c;因为它是数字签名的。 1.1 什么时候应该⽤…

Spring Security 6 的权限授权验证失败

我第一次完成了认证 &#xff0c;然后在授权验证那里出来了问题&#xff0c;我也不知道&#xff0c;教程是sangen 那个教程。跟着敲&#xff0c;我知道我的版本不对&#xff0c;但是我最后还是new bing 解决我的bug . 带token的时候就说明 &#xff0c;认证就已经成功的&#x…

node开通阿里云短信验证服务,代码演示 超级详细

阿里云官网步骤&#xff1a;Node.js SDK (aliyun.com) 首先先搭建一个node项目&#xff1a;app.js const express require(express); // 引入 Express 框架const app express(); app.use(express.json()); // 解析请求中的 JSON 数据const PORT process.env.PORT || 3000; …

浅谈全局视角下的设计模式

写在前面&#xff1a; 以下内容&#xff0c;更多的是自己的思考总结&#xff0c;不可避免出现有争议的地方&#xff0c;请谨慎食用。 浅谈全局视角下的设计模式1、业务开发经常使用的设计模式有哪些&#xff1f;2、为什么有些设计模式不常见呢&#xff1f;3、为什么这些设计模式…

VIM 编辑器使用教程

我们如果要在终端模式下进行文本编辑或者修改文件就可以使用 VI/VIM 编辑器&#xff0c;Ubuntu 自带了 VI 编辑器&#xff0c;但是 VI 编辑器对于习惯了 Windows 下进行开发的人来说不方便&#xff0c;比如竟然 不能使用键盘上的上下左右键调整光标位置。因此我推荐大家使用 V…

基于5G技术的智能导航机器人及AR巡逻应用开发项目实施方案(上)

目录 1 项目总体概述 1.1 项目背景 1.2 建设内容 1.3 建设目标 2 项目需求理解 2.1 业务需求 2.2 功能需求 3 项目技术方案 3.1 建设方案 3.1.1 设计思路 3.1.2 架构设计 3.1.3 功能实现 3.2 安全方案 3.2.1 系统安全原则 3.2.2 系统安全措施 4…

linux 集群时间同步

前言 由于搭建hadoop集群需要进行集群时间同步&#xff0c;记录下具体操作过程。 这里我的集群环境为192.168.184.129&#xff08;主&#xff09;、192.168.184.130&#xff08;从&#xff09;、192.168.184.131&#xff08;从&#xff09;&#xff0c;设置从机器从主机器同步…

使用Docker快速创建一个Jenkins服务

目录 1.安装Docker 2.查看有哪些镜像&#xff0c;获取Jenkins镜像 3.查看已拥有的镜像 4.启动容器 5.查看容器运行 6.【配置】--从网页访问&#xff0c;对Jenkins进行配置 6.1.访问 6.2.初次使用&#xff0c;插件安装 6.3.初次使用&#xff0c;创建用户 7.配置完成后…

Android双目三维重建:Android双目摄像头实现双目测距

Android双目三维重建&#xff1a;Android双目摄像头实现双目测距 目录 Android双目三维重建&#xff1a;Android双目摄像头实现双目测距 1.开发版本 2.Android双目摄像头 3.双目相机标定 (1)双目相机标定-Python版 (2)双目相机标定-Matlab版 4.相机参数配置 5.Android 双…
最新文章