二叉树的垂直遍历

news2025/1/16 21:55:14

1.题目

这道题是2024-2-13的签到题,题目难度为困难。

考察的知识点是DFS算法和自定义排序。

题目链接:二叉树的垂直遍历

给你二叉树的根结点 root ,请你设计算法计算二叉树的 垂序遍历 序列。

对位于 (row, col) 的每个结点而言,其左右子结点分别位于 (row + 1, col - 1) 和 (row + 1, col + 1) 。树的根结点位于 (0, 0) 。

二叉树的 垂序遍历 从最左边的列开始直到最右边的列结束,按列索引每一列上的所有结点,形成一个按出现位置从上到下排序的有序列表。如果同行同列上有多个结点,则按结点的值从小到大进行排序。

返回二叉树的 垂序遍历 序列。

2.思路

说实话,之前碰到的困难题目大部分我都是直接放弃的,但是通过这段时间对DFS算法的使用后我尝试独立解决这道题,发现还是可以解出来的。这道题其实有两大难点:

  1. 如何得到所有列的所有结点
  2. 如何让每列的结点按照题目要求排序

下面是我对这道题的所有思路:

初步思路——如何理解坐标

对于题目中的要求,根节点的坐标为(0,0),其它坐标都符合以下规律:

对于所有的左子结点,它的坐标为(x_parent+1,y_parent-1)。

对于所有的右子结点,它的坐标为(x_parent+1,y_parent+1)。

其中x_parent是这些节点的父节点x坐标值,y_parent是这些结点的父节点y坐标值。

选择什么算法来解题——DFS算法

其实刚开始我是打算用BFS算法来解题的,因为根据这道题的结果来看,它里面的列表结果值是根据结点的x坐标排序的,但如果使用BFS算法有一个问题,就是我如何在BFS遍历过程中读取父节点的坐标呢?因为这个坐标是我们自己定义的,并不是TreeNode自带的属性。因此我想到了使用DFS遍历。

对于DFS遍历,它一般都是用递归的方式来写的,因此我可以给递归函数加上两个参数用来传入父节点的x坐标和y坐标。同时我们根据前面的坐标规律来进行子结点遍历。对于每个结点,我们利用一个结构来存储它们的信息——字典(哈希表)。这样我们就可以把每个列的所有结点信息保留。

怎么按照题目要求排序?

在完成DFS遍历所有节点后我们能够得到所有列的所有结点,但这就完事了吗?它还有一个难点,我们还需要进行排序,因此我们得弄清楚题目的排序要求:

  1. 根据列的值来排序(升序)
  2. 根据行的值来排序(升序)
  3. 根据结点的值排序(升序)

由于我比较喜欢用python来写算法题目,因此这里我借助python的sorted函数、lambda表达式等python内置语法来写一些排序规则,下面是我的排序整体思路:

首先我们用字典的内置函数items()函数来获取一个迭代器对象,并将这个迭代器传入到sorted函数里面(进行排序),排序规则按照字典的键来升序排序。

将前面得到的迭代器对象根据结点的列排序后,我们还需要根据后面两个排序规则排序,这里我们利用python的for循环来获取前面的迭代器对象元素,同时我们还要借助元组的拆包语法来获取对应的两个子元素:sk,val。

我们需要对val进行自定义排序,排序规则根据每个元素的行和值进行排序。最后我们利用列表表达式来得到每一列的所有节点值,并存入到结果列表中。

最后我们直接返回结果列表就行了。

3.代码

# Definition for a binary tree node.
# class TreeNode:
#     def __init__(self, val=0, left=None, right=None):
#         self.val = val
#         self.left = left
#         self.right = right
class Solution:
    def verticalTraversal(self, root: Optional[TreeNode]) -> List[List[int]]:
        # 定义一个字典,用来存储每一列的结点信息
        rst = {}
        # 定义DFS函数,这里是前序遍历
        def dfs(node,x,y):
            # 如果结点存在的话
            if node:
                # 如果rst里面没有第y列的话,则初始化第y列的列表信息
                # 其中,x是当前结点的行,node.val是当前结点的值
                if y not in rst:
                    rst[y] = [(x,node.val)]
                # 如果rst里面有第y列的话,则添加第y列的列表信息
                else:
                    rst[y].append((x,node.val))
                # 剪枝操作,如果当前结点存在左子结点
                if node.left:
                    dfs(node.left,x+1,y-1)
                # 剪枝操作,如果当前结点存在右子结点
                if node.right:
                    dfs(node.right,x+1,y+1)

        # DFS遍历root结点
        dfs(root,0,0)
        # 获取前面的字典迭代器对象(排序后的)
        # 根据列来排序
        sort_key = sorted(rst.items(),key=lambda x:x[0])
        # 保存最终结果
        ans = []
        # 利用拆包和循环遍历前面的迭代器对象
        for sk,val in sort_key:
            # 将每列的结点信息按照行和它的值来排序
            val = sorted(val,key=lambda x:[x[0],x[1]])
            # 利用列表推导式来获取最终的格式结果
            tmp = [v[1] for v in val]
            # 添加到结果列表里面
            ans.append(tmp)
        return ans

        
                

4.总结

        今天的这道签到题是今年(2024)我第一道有成就感的题目,毕竟是今年第一道自己独立解决的困难题。过年的这几天签到题都是DFS算法或BFS算法,这些天的练习让我对这两种算法有更深的理解。今天的这道题更是让我对前些天的练习有一个综合运用。也让我对之后的算法练习和学习有更大的鼓舞,算法这个东西如果我们能够凭借自己的努力解出来那是相当有成就感的,上次有这种成就感还是大一的时候做高数题。

总而言之,算法思维并不是天生就有的,我也并不是天赋很好的选手,只能凭借每天的算法练习来学习和掌握常见的算法题。俗话说一个人走的更快,一群人走的更远。这段时间的算法练习中,我将自己每天的算法思路分享给大家参考,这不仅是让我对这道题进一步的分析,也能够给大家一点参考,最后祝大家新年快乐!。

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

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

相关文章

Spark编程实验六:Spark机器学习库MLlib编程

目录 一、目的与要求 二、实验内容 三、实验步骤 1、数据导入 2、进行主成分分析(PCA) 3、训练分类模型并预测居民收入 4、超参数调优 四、结果分析与实验体会 一、目的与要求 1、通过实验掌握基本的MLLib编程方法; 2、掌握用MLLib…

软件实例分享,宠物店兽医电子处方开单系统软件教程

软件实例分享,宠物店兽医电子处方开单系统软件教程 一、软件教程问答 以下教程以 佳易王宠物店兽医电子处方软件V16.0为例说明 软件文件下载可以点击最下方官网卡片——软件下载——试用版软件下载 问:宠物医院电子处方单子使用的纸张大小是多少&…

19 删除链表的倒数第 N 个结点

19. 删除链表的倒数第 N 个结点 中等 相关标签 相关企业 提示 给你一个链表,删除链表的倒数第 n 个结点,并且返回链表的头结点。 这段代码使用了双指针的方法,其中一个指针先走 n 步,然后两个指针一起走,直到第一…

鸿蒙(HarmonyOS)项目方舟框架(ArkUI)之LoadingProgress组件

鸿蒙(HarmonyOS)项目方舟框架(ArkUI)之LoadingProgress组件 一、操作环境 操作系统: Windows 10 专业版、IDE:DevEco Studio 3.1、SDK:HarmonyOS 3.1 二、LoadingProgress组件 用于显示加载动效的组件。 子组件 无 接口 L…

【Linux学习】生产者-消费者模型

目录 22.1 什么是生产者-消费者模型 22.2 为什么要用生产者-消费者模型? 22.3 生产者-消费者模型的特点 22.4 BlockingQueue实现生产者-消费者模型 22.4.1 实现阻塞队列BlockQueue 1) 添加一个容器来存放数据 2)加入判断Blocking Queue情况的成员函数 3)实现push和pop方法 4)完…

使用word2vec+tensorflow自然语言处理NLP

目录 介绍: 搭建上下文或预测目标词来学习词向量 建模1: 建模2: 预测: 介绍: Word2Vec是一种用于将文本转换为向量表示的技术。它是由谷歌团队于2013年提出的一种神经网络模型。Word2Vec可以将单词表示为高维空间…

JAVA-多进程开发-创建等待进程

前言 在项目中,为了实现“并发编程”(同时执行多个任务),就引入了“多进程编程”,把一个很大的任务,拆分成若干个很小的任务,创建多个进程,每个进程分别负责其中的一部分任务。 这也…

Java实现中学生家校互联系统 JAVA+Vue+SpringBoot+MySQL

目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 学生管理模块2.2 课堂表现模块2.3 考试成绩模块2.4 家校留言模块2.5 校园通知模块 三、系统设计3.1 用例设计3.2 实体类设计3.2.1 课堂表现实体类设计3.2.2 考试成绩实体类设计3.2.3 家校留言实体类设计3.2.4 校园通知实…

虚拟人专题报告:虚拟人深度产业分析报告

今天分享的是虚拟人系列深度研究报告:《虚拟人专题报告:虚拟人深度产业分析报告》。 (报告出品方:Q量子位) 报告共计:18页 技术背景 虚拟数字人指存在于非物理世界中,由计算机图形学、图形渲…

【Vue】工程化开发脚手架Vue CLI

📝个人主页:五敷有你 🔥系列专栏:Vue⛺️稳重求进,晒太阳 工程化开发&脚手架Vue CLI 基本介绍 Vue Cli是Vue官方提供的一个全局命令工具 可以帮助我们快速创建一个开发Vue项目的标准化基础架子【集成了we…

【小沐学GIS】基于C++QT绘制三维数字地球Earth(OpenGL)

🍺三维数字地球系列相关文章如下🍺:1【小沐学GIS】基于C绘制三维数字地球Earth(456:OpenGL、glfw、glut)第一期2【小沐学GIS】基于C绘制三维数字地球Earth(456:OpenGL、glfw、glut)第二期3【小沐…

四、OpenAI之文本生成模型

文本生成模型 OpenAI的文本生成模型(也叫做生成预训练的转换器(Generative pre-trained transformers)或大语言模型)已经被训练成可以理解自然语言、代码和图片的模型。模型提供文本的输出作为输入的响应。对这些模型的输入内容也被称作“提示词”。设计提示词的本质是你如何对…

python 经典老人言

python 经典老人言 import tkinter as tkclass FlipBook:def __init__(self, master):self.master master master.title("经 典 老 人 言")self.pages ["经 典 老 人 言","求学无笨者,努力就成功","读 书 百 遍&am…

代码随想录|day 16

Day 16 迎财神 坚持如此hard 玄之又玄,众妙之门 一、理论知识 回顾【深度】和【高度】的概念,现在主要还是写递归2) 初识【回溯】3)左叶子的明确定义:节点A的左孩子不为空,且左孩子的左右孩子都为空&am…

Python学习之路-爬虫提高:scrapy基础

Python学习之路-爬虫提高:scrapy基础 为什么要学习scrapy 通过前面的学习,我们已经能够解决90%的爬虫问题了,那么scrapy是为了解决剩下的10%的问题么,不是,scrapy框架能够让我们的爬虫效率更高 什么是scrapy Scrapy是一个为了…

(三十七)大数据实战——Solr服务的部署安装

前言 Solr是一个基于Apache Lucene的开源搜索平台,它提供了强大的全文搜索、分布式搜索和数据分析功能。Solr 可以用于构建高性能的搜索应用程序,支持从海量数据中快速检索和分析信息。Solr 使用倒排索引和先进的搜索算法,可实现快速而准确的…

AI绘画作品的展示和变现-2

4.7 制作红包封面 中国的节日和传统文化元素仍然可以成为创作者们的创作灵感,创造出更多的变现机会。比如元宵节,可以制作大型元宵图案,进行引流并卖出元宵。 而春分、谷雨等节气也可以成为创作的灵感来源,创作出与之相关的图案&…

最新wordpress外贸主题

日用百货wordpress外贸主题 蓝色大气的wordpress外贸主题,适合做日用百货的外贸公司搭建跨境电商网站使用。 https://www.jianzhanpress.com/?p5248 添加剂wordpress外贸建站主题 橙色wordpress外贸建站主题,适合做食品添加剂或化工添加剂的外贸公司…

软考25-上午题-图2

一、图的存储 图的基本存储结构:邻接矩阵、邻接链表。 1-1、邻接矩阵 用矩阵来表示图中顶点之间的关系。 示例1:有向图的邻接矩阵 示例2:无向图的邻接矩阵 无向图的邻接矩阵是对称的!!! 借助邻接矩阵可…

Linux系统之部署File Browser文件管理系统

Linux系统之部署File Browser文件管理系统 一、File Browser介绍1.1 File Browser简介1.2 File Browser功能1.3 File Browser使用场景 二、本地环境介绍2.1 本地环境规划2.2 本次实践介绍 三、检查本地环境3.1 检查本地操作系统版本3.2 检查系统内核版本 四、安装File Browser4…