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

广西钦州有人帮做网站的公司吗百度平台商家联系方式

广西钦州有人帮做网站的公司吗,百度平台商家联系方式,如何做环保管家网站,国企网站建设合同title: 剑指 Offer 06. 从尾到头打印链表 tags: 链表递归迭代 categories:算法剑指 Offer 题目描述 输入一个链表的头节点,从尾到头反过来返回每个节点的值(用数组返回)。 示例 1: 输入:head [1,3,2] 输出&#…

title: 剑指 Offer 06. 从尾到头打印链表 tags:

  • 链表
  • 递归
  • 迭代 categories:
  • 算法
  • 剑指 Offer

题目描述

输入一个链表的头节点,从尾到头反过来返回每个节点的值(用数组返回)。

示例 1:

输入:head = [1,3,2]
输出:[2,3,1]

限制:

$0 <= 链表长度 <= 10000$


算法 1

(迭代) $O(n)$

从前往后遍历链表,存储每个节点的值到答案数组中,然后反转答案数组就是从尾到头打印链表的结果。

时间复杂度

$O(n)$

空间复杂度

$O(n)$

C++ 代码
/*** Definition for singly-linked list.* struct ListNode {*     int val;*     ListNode *next;*     ListNode(int x) : val(x), next(NULL) {}* };*/
class Solution {
public:vector<int> reversePrint(ListNode* head) {vector<int> res;for (auto p = head; p; p = p->next) res.push_back(p->val);reverse(res.begin(), res.end());return res;}
};
Java 代码
/*** Definition for singly-linked list.* public class ListNode {*     int val;*     ListNode next;*     ListNode(int x) { val = x; }* }*/
class Solution {public int[] reversePrint(ListNode head) {List<Integer> resList = new ArrayList<>();ListNode p = head;while (p != null) {resList.add(p.val);p = p.next;}Collections.reverse(resList);int[] res = new int[resList.size()];for (int i = 0; i < resList.size(); i ++ ) {res[i] = resList.get(i);}return res;}
}
Python 代码
# Definition for singly-linked list.
# class ListNode:
#     def __init__(self, x):
#         self.val = x
#         self.next = Noneclass Solution:def reversePrint(self, head: ListNode) -> List[int]:res_list = []p = headwhile p:res_list.append(p.val)p = p.nextreturn res_list[::-1]

算法 2

(递归) $O(n)$

递归的出口条件:当前节点为空,返回空数组。 递归逻辑:先递归到最后一个节点,然后从最后一个节点开始将节点值存储到答案数组中,递归函数不断弹栈,最后答案数组中存储的就是从尾到头打印链表的结果。

时间复杂度

$O(n)$

空间复杂度

存储答案的空间 $O(n)$,包含递归系统栈所需的空间 $O(n)$。

C++ 代码
/*** Definition for singly-linked list.* struct ListNode {*     int val;*     ListNode *next;*     ListNode(int x) : val(x), next(NULL) {}* };*/
class Solution {
public:vector<int> res;vector<int> reversePrint(ListNode* head) {if (!head) return {};reversePrint(head->next);res.push_back(head->val);return res;}
};
Java 代码
/*** Definition for singly-linked list.* public class ListNode {*     int val;*     ListNode next;*     ListNode(int x) { val = x; }* }*/
class Solution {List<Integer> res = new ArrayList<>();public int[] reversePrint(ListNode head) {reverseList(head);int[] result = new int[res.size()];for (int i = 0; i < res.size(); i ++ ) {result[i] = res.get(i);}return result;}private void reverseList(ListNode head) {if (head == null) return;reverseList(head.next);res.add(head.val);}
}
Python 代码
# Definition for singly-linked list.
# class ListNode:
#     def __init__(self, x):
#         self.val = x
#         self.next = Noneclass Solution:def reversePrint(self, head: ListNode) -> List[int]:self.res = []def reverseList(node):if not node:returnreverseList(node.next)self.res.append(node.val)reverseList(head)return self.res

推荐阅读:

  • https://www.mianshi.online
  • https://www.i9code.cn

    本文由博客一文多发平台 OpenWrite 发布!

http://www.hkea.cn/news/977541/

相关文章:

  • 网页设计最牛的网站建设宁波网站优化公司哪家好
  • 建设通查询如何做网站推广及优化
  • 城乡建设网站首页百度seo收录软件
  • 永久免费建个人网站培训网站建设
  • 如何使用jq做弹幕网站好用的磁力搜索引擎
  • 南充营销型网站建设高端品牌网站建设
  • 制作小程序和网站的公司搜狗收录提交入口网址
  • 手机站电影基础建站如何提升和优化
  • 江苏 网站备案百度贴吧官网app下载
  • 网站制作三站湖南网站seo公司
  • 简单做任务赚钱网站企业管理培训课程报名
  • 零点研究咨询集团官方网站建设相似图片在线查找
  • 网站开发需要什么软件关键词app
  • 360全景网站建设做了5天游戏推广被抓了
  • 政府网站建设经验典型材料河源今日头条新闻最新
  • 为什么要进行网站备案佛山市人民政府门户网站
  • 摄影网站开发背景百度app交易平台
  • 吉林网站建设石家庄百度快照优化排名
  • 大学生网站开发总结报告app推广接单发布平台
  • 自己做的网站怎么推广seo顾问培训
  • 怎么做业务网站百度搜索提交入口
  • 网页设计网站图片西安百度推广运营公司
  • 济南网站开发推广网络服务包括
  • 五星级酒店网站建设关键词歌词表达的意思
  • 浙江高端建设网站网站关键词如何优化
  • 2017网站开发工程师五合一网站建设
  • 学编程的孩子有什么好处seo网站诊断文档案例
  • 广州中新知识城开发建设网站无锡百姓网推广
  • 宝鸡做网站费用关键词你们懂的
  • wordpress 仿站 教程百度竞价点击一次多少钱