面试经典150题(65-66)

leetcode 150道题 计划花两个月时候刷完,今天(第三十一天)完成了2道(65-66)150:

65.(106. 从中序与后序遍历序列构造二叉树)题目描述:

给定两个整数数组 inorder 和 postorder ,其中 inorder 是二叉树的中序遍历, postorder 是同一棵树的后序遍历,请你构造并返回这颗 二叉树 。

第一版(这个和昨天的给了中序和先序去构造二叉树差不多,先序《根左右》,后序《左右根》,还是递归)

class Solution {Map<Integer,Integer> map=new HashMap();public TreeNode buildTree(int[] inorder, int[] postorder) {for(int i=0;i<inorder.length;i++){map.put(inorder[i],i);}return buildSubTree(inorder,0,inorder.length-1,postorder,0,postorder.length-1);}public TreeNode buildSubTree(int[] inorder, int iStart,int iEnd,int[] postorder,int pStart,int pEnd) {if(iStart>iEnd||pStart>pEnd){return null;}if(pStart==pEnd){return new TreeNode(postorder[pEnd]);}TreeNode root=new TreeNode(postorder[pEnd]);int rootIndex=map.get(postorder[pEnd]);int count=rootIndex-iStart;root.left=buildSubTree(inorder,iStart,rootIndex-1,postorder,pStart,pStart+count-1);root.right=buildSubTree(inorder,rootIndex+1,iEnd,postorder,pStart+count,pEnd-1);return root;}
}

66.(117. 填充每个节点的下一个右侧节点指针 II)题目描述:

给定一个二叉树:
struct Node {int val;Node *left;Node *right;Node *next;
}
填充它的每个 next 指针,让这个指针指向其下一个右侧节点。如果找不到下一个右侧节点,则将 next 指针设置为 NULL 。
初始状态下,所有 next 指针都被设置为 NULL 。

第一版(一看到这题就想到了层次遍历,所以第一版就层次遍历去实现的,只需要把层次遍历框架先写出来,然后再加上一个当前层的前一个节点的变量记录就可以了)

class Solution {public Node connect(Node root) {if(root==null)return root;Queue<Node> queue=new LinkedList();queue.offer(root);while(!queue.isEmpty()){int currNum=queue.size();Node preNode=null;while(currNum!=0){Node temp=queue.poll();if(temp.left!=null){if(preNode!=null){preNode.next=temp.left;}preNode=temp.left;queue.offer(temp.left);}if(temp.right!=null){if(preNode!=null){preNode.next=temp.right;  }preNode=temp.right;queue.offer(temp.right);}currNum--;}}return root;}
}

第二版(看了解题,用上了题目中next指针,可以减少空间复杂度)


class Solution {public Node connect(Node root) {if(root==null){return root;}// 用 next 坐标串起来,先用上一层的把下一层的串好Node startNode=root;while(startNode!=null){Node preNode=null;// 记录下一层的 第一个节点Node lastNode=null;for(Node leftNode=startNode;leftNode!=null;leftNode=leftNode.next){if(leftNode.left!=null){if(lastNode==null){lastNode=leftNode.left;}if(preNode!=null){preNode.next=leftNode.left;}preNode=leftNode.left;}if(leftNode.right!=null){if(lastNode==null){lastNode=leftNode.right;}if(preNode!=null){preNode.next=leftNode.right;}preNode=leftNode.right;}}startNode=lastNode;}return root;}
}

这几天还在发懒中。。。不知道为啥。。还找了一个好看的动漫。。buff 拉满了。

第三十一天,加油,早日跳槽!!!

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

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

相关文章

Impala-查询Kudu表详解(超详细)

文章目录 前言一、使用Impala查询kudu表介绍1. 使用Impala与Kudu表的好处2. 配置Impala以使用Kudu3. Kudu副本因子 二、Impala DDL增强功能1. Kudu表的主键列2. Kudu表特定的列属性1. 主键属性2. NULL | NOT NULL属性3. DEFAULT属性4. ENCODING属性5. COMPRESSION属性6. BLOCK_…

Linux之IP地址、主机名、域名解析

一、IP地址 可以通过ifconfig命令查看本机的ip地址&#xff0c;如果无法使用ifconfig命令&#xff0c;可以安装 安装&#xff1a;yum -y install net-tools ens33&#xff1a;主网卡&#xff0c;里面的inet就是ip地址 lo&#xff1a;本地回环网卡&#xff0c;127.0.0.1&…

Apache Doris (六十): Doris - 物化视图

🏡 个人主页:IT贫道_大数据OLAP体系技术栈,Apache Doris,Clickhouse 技术-CSDN博客 🚩 私聊博主:加入大数据技术讨论群聊,获取更多大数据资料。 🔔 博主个人B栈地址:豹哥教你学编程的个人空间-豹哥教你学编程个人主页-哔哩哔哩视频 目录

OpenHarmony—开发环境搭建

背景 因为没有实体的开发硬件&#xff0c;且不想破坏原有的Linux环境&#xff0c;所以这里基于 Docker QEMU 搭建开发环境 宿主机Linux系统命令行方式DockerQEMU 6.2 Docker环境准备 安装Docker 在Ubuntu中&#xff0c;可以使用下面的命令来安装Docker&#xff1a; sudo …

考研复试复习-算法笔记(1前言)

1、PAT Programming Ability Test,是考察计算机程序设计能力的一个考试&#xff0c;分为三级&#xff0c;顶级将涉及到大量ACM-ICPC竞赛的考点 今年春季的话截止时间为 2024 年 2 月 29 日 23:59&#xff0c;要是考研没考上的兄弟姐妹们可以考虑以下这个&#xff0c;这个等级证…

androidStudio sync failed GradlePropertiesModel (V2)

大家在增加模块的时候经常遇到吧&#xff1f;重启后就好了。 Cannot get GradlePropertiesModel (V2) for project ‘GradleProject{path’:app’}’ 然而&#xff0c;今天开机以后&#xff0c;无论如何&#xff0c;点击gradle的大象图标(Sync Project with Gradle Files)&…

详细解读QLC SSD无效编程问题-4

对于这些全部页面被无效化的WL&#xff0c;执行第二次编程实际上是不必要的&#xff0c;但当前的策略并未注意到这一问题。而对于那些既有有效页面又有无效页面&#xff08;图11中显示为1到3个&#xff09;的WL&#xff0c;应当被编程&#xff0c;但可以利用这些无效信息来改进…

springboot实现用户操作日志记录

springboot实现用户操作日志记录 简介&#xff1a;之前写了《aop实现日志持久化记录》一文&#xff0c;主要介绍自定义aop标注方法上&#xff0c;通过切面方法对用户操作插入mysql。思路正确但是实际操作上存在一些小问题&#xff0c;本文将从项目出发&#xff0c;对细节进行补…

UE5.1_Python使用1

UE5.1_Python使用1 目录 UE5.1_Python使用1 1. 问题及链接: 2. 使用: UE5-Python依赖:

【JaveWeb教程】(2)Web前端基础:JavaScript入门不再难:一篇文章教你轻松搞定JavaScript的基础语法与函数

目录 1 介绍2 引入方式3 基础语法3.1 书写语法3.2 变量3.3 数据类型和运算符 4 函数4.1 第一种定义格式4.2 第二种定义格式 html完成了架子&#xff0c;css做了美化&#xff0c;但是网页是死的&#xff0c;我们需要给他注入灵魂&#xff0c;所以接下来我们需要学习JavaScript&a…

普通用户用哪款电脑杀毒软件最好?

前言 各位小伙伴接触到电脑的时候&#xff0c;都一定有听过“电脑一定要安装杀毒软件”这句话。 毕竟在电脑诞生之初到今天&#xff0c;电脑木马和病毒依旧存在。 中了木马或病毒的电脑会出现什么现象&#xff1f;具体得看中了什么样的病毒。 但轻则资料泄漏、电脑瘫痪&…

生成式AI:重塑开发流程与开发工具的革命性

生成式AI&#xff1a;重塑开发流程与开发工具 1. 自动化代码生成&#xff1a;提高开发效率2. 智能需求分析&#xff1a;准确理解用户需求3. 实时测试与优化&#xff1a;提高软件质量与稳定性4. 总结 随着人工智能技术的飞速发展&#xff0c;生成式AI已经逐渐成为软件开发领域的…

SSL/TLS 握手过程详解

SSL握手过程详解 1、SSL/TLS 历史发展2、SSL/TLS握手过程概览2.1、协商交换密码套件和参数2.2、验证一方或双方的身份2.3、创建/交换对称会话密钥 3、TLS 1.2 握手过程详解4、TLS 1.3 握手过程详解5、The TLS 1.2 handshake – Diffie-Hellman Edition 1、SSL/TLS 历史发展 可…

自然语言转SQL,一个微调ChatGPT3.5的实例(下)--模型微调及模型性能

提交训练集进行微调 一旦我们创建了JSONL文件&#xff08;可以在这里或ipfs_here找到一个小样本&#xff09;&#xff0c;下一步是使用以下命令将创建的文件上传到OpenAI&#xff1a; openai.api_key os.getenv("OPENAI_API_KEY") print(openai.File.create(fileo…

【水浸传感器】软硬件一体水浸监测整套方案远程监测解决各种环境漏水问题

一、痛点分析 在工业生产中&#xff0c;水浸传感器可以安装在数据中心、半导体厂房、输油管道、车间仓库、变电室等易发生水浸的区域。一旦检测到漏水情况&#xff0c;立即发出信号反馈。然而&#xff0c;水浸传感器分散在各个地点&#xff0c;导致管理不集中、不便捷&#xf…

Fiber Golang 中的路由和中间件

掌握 GoLang Fiber 中的路由和中间件艺术&#xff0c;以进行高效的 Web 开发 在网络开发领域中&#xff0c;创建一个有效地路由和管理各种任务的 Web 应用程序至关重要。路由决定了如何处理传入的请求&#xff0c;而中间件在执行任务&#xff0c;如身份验证、日志记录和请求解…

基于SpringBoot的企业资产管理系统

文章目录 项目介绍主要功能截图:部分代码展示设计总结项目获取方式🍅 作者主页:超级无敌暴龙战士塔塔开 🍅 简介:Java领域优质创作者🏆、 简历模板、学习资料、面试题库【关注我,都给你】 🍅文末获取源码联系🍅 项目介绍 基于SpringBoot的企业资产管理系统,java…

设计一个基于MapReduce的算法,求出数据集中的最小值。假设Reducer任务数量大于1,请简要描述该算法(可使用分区. 合并过程)

设计一个基于MapReduce的算法&#xff0c;求出数据集中的最小值。假设Reducer任务数量大于1&#xff0c;请简要描述该算法(可使用分区. 合并过程) 设计一个基于MapReduce的算法来求数据集中的最小值需要考虑如何在多个Reducer任务中分配和合并工作。这里是算法的简要描述&…

力扣刷题-二叉树-最大二叉树

654.最大二叉树 给定一个不含重复元素的整数数组。一个以此数组构建的最大二叉树定义如下&#xff1a; 二叉树的根是数组中的最大元素。 左子树是通过数组中最大值左边部分构造出的最大二叉树。 右子树是通过数组中最大值右边部分构造出的最大二叉树。 通过给定的数组构建最大…

数据挖掘 模糊聚类

格式化之前的代码&#xff1a; import matplotlib.pyplot as plt#绘图 import pandas as pd#读取数据集 from sklearn.preprocessing import scale from sklearn.cluster import DBSCAN#聚类 from sklearn import preprocessing#数据预处理的功能&#xff0c;包括缩放、标准化…