剑指 Offer 06. 从尾到头打印链表
1.题目:
输入一个链表的头节点,从尾到头反过来返回每个节点的值(用数组返回)。
示例 1:
输入:head = [1,3,2]
输出:[2,3,1]
限制:
0 <= 链表长度 <= 10000
2.分析与代码:
方法一:递归
(1)用递归将链表中的数据一个一个放入tmp数组,因为是递归,所以tmp中的数据已经是反序的了,可以直接返回。
代码如下:
/** * Definition for singly-linked list. * struct ListNode { * int val; * ListNode *next; * ListNode(int x) : val(x), next(NULL) {} * }; */ class Solution { vector<int> tmp; public: vector<int> reversePrint(ListNode* head) { //递归 recur(head); return tmp; } void recur(ListNode* head){ if(head == NULL) return ; recur(head->next); tmp.push_back(head->val); } };
(2)时间复杂度分析:递归算法的时间复杂度本质上是要看: 递归的次数 * 每次递归中的操作次数。
代码中递归了n次,每一次递归都进行1次push_back操作,所以时间复杂度为O(n)。
空间复杂度分析:使用了tmp数组,为O(1)。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
2021-08-11 如何用Git上传项目到GitHub或者码云?
2021-08-11 Git出错:“Please make sure you have the correct access rights and the repository exists.”