RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1247517
Accepted
A K
A K
Asked:2022-02-23 10:50:53 +0000 UTC2022-02-23 10:50:53 +0000 UTC 2022-02-23 10:50:53 +0000 UTC

将数组转换为二叉树

  • 772

我有一个代表二叉树的数字数组:

var data = new object[] { 1, 2, 3, 4, null, null, 5 };

我需要将其转换为经典形式:

在此处输入图像描述

(每个数字依次为中、左、右。如果为null,则跳过该节点)

public class TreeNode
{
    public int val;
    public TreeNode left;
    public TreeNode right;
    public TreeNode(int val = 0, TreeNode left = null, TreeNode right = null)
    {
        this.val = val;
        this.left = left;
        this.right = right;
    }
}

我想出了一种能产生预期结果的构造方法:

private TreeNode CreateTree(object[] data)
{
    TreeNode[] nodes = data.Select(x => x == null ? null : new TreeNode((int)x, null, null)).ToArray();

    int current = 0;
    bool left = true;

    for (int i = 1; i < nodes.Length; i++)
    {
        if (left)
        {
            nodes[current].left = nodes[i];
            left = false;
        }
        else
        {
            nodes[current].right = nodes[i];
            left = true;

            current++;
            while (current < nodes.Length  && nodes[current] == null)
                current++;
        }
    }

    return nodes[0];
}

在此处输入图像描述

但在我看来,这是一种弯曲的自行车,您可以以某种方式更优雅地将宽度旁路(BFS / LOT)与深度旁路(DFS Preorder:中,左,右)结合起来。

有谁知道如何根据经典解决类似的问题?

c#
  • 1 1 个回答
  • 10 Views

1 个回答

  • Voted
  1. Best Answer
    tym32167
    2022-02-23T11:48:11Z2022-02-23T11:48:11Z

    那么,有哪些选择?

    线路旁路(从末端)

    它类似于 BFS,只是相反。

    private TreeNode CreateTree(object[] data)
    {
        var nodes = new Dictionary<int, TreeNode>();
    
        for (int i = data.Length - 1; i >= 0; i--)
        {
            object val = data[i];
            if (val == null) continue;
            int index = i + 1;
    
            nodes.TryGetValue(index * 2, out TreeNode left);
            nodes.TryGetValue(index * 2 + 1, out TreeNode right);
    
            var node = new TreeNode((int)val, left, right);
            nodes[index] = node;
        }
    
        nodes.TryGetValue(1, out TreeNode root);    
        return root;
    }
    

    诀窍是bool left = true;您不需要这个,因为节点索引可以理解左节点或右节点。

    输出与您的相同。

    DFS 风格

    一个简单的递归。

    private TreeNode CreateTreeDFS(object[] data)
    {
        return CreateTreeDFS(data, 0);
    }
    
    private TreeNode CreateTreeDFS(object[] data, int index)
    {
        if (index < 0 || index >= data.Length) return null;
        
        var val = data[index];
        if (val == null) return null;
        
        return new TreeNode((int)val, CreateTreeDFS(data, (index + 1) * 2 - 1), CreateTreeDFS(data, (index + 1) * 2));
    }
    

    输出与您的相同。

    bfs 风格

    最愚蠢的恕我直言,因为在通道之前有必要提前创建所有节点。

    private TreeNode CreateTreeBFS(object[] data)
    {
        var nodes = new Dictionary<int, TreeNode>();
    
        for (int i = 0; i < data.Length; i++)
        {
            object val = data[i];
            if (val == null) continue;
            int index = i + 1;
            
            var node = new TreeNode((int)val, null, null);
            nodes[index] = node;
        }
        
        foreach(var key in nodes.Keys)
        {
            nodes.TryGetValue(key * 2, out TreeNode left);
            nodes.TryGetValue(key * 2 + 1, out TreeNode right);
            
            var node = nodes[key];
            node.left = left;
            node.right = right;
        }
    
        nodes.TryGetValue(1, out TreeNode root);
        return root;
    }
    

    用于创建节点的 Linq 选项

    private TreeNode CreateTreeBFS(object[] data)
    {
        var nodes = data.Select((v, ind) => (v, ind))
            .Where(x => x.v != null)
            .ToDictionary(x => x.ind +1, x => new TreeNode((int)x.v, null, null));
    
        foreach (var key in nodes.Keys)
        {
            nodes.TryGetValue(key * 2, out TreeNode left);
            nodes.TryGetValue(key * 2 + 1, out TreeNode right);
    
            var node = nodes[key];
            node.left = left;
            node.right = right;
        }
    
        nodes.TryGetValue(1, out TreeNode root);
        return root;
    }
    

    输出与您的相同。

    • 4

相关问题

  • 使用嵌套类导出 xml 文件

  • 分层数据模板 [WPF]

  • 如何在 WPF 中为 ListView 手动创建列?

  • 在 2D 空间中,Collider 2D 挂在玩家身上,它对敌人的重量相同,我需要它这样当它们碰撞时,它们不会飞向不同的方向。统一

  • 如何在 c# 中使用 python 神经网络来创建语音合成?

  • 如何知道类中的方法是否属于接口?

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    表格填充不起作用

    • 2 个回答
  • Marko Smith

    提示 50/50,有两个,其中一个是正确的

    • 1 个回答
  • Marko Smith

    在 PyQt5 中停止进程

    • 1 个回答
  • Marko Smith

    我的脚本不工作

    • 1 个回答
  • Marko Smith

    在文本文件中写入和读取列表

    • 2 个回答
  • Marko Smith

    如何像屏幕截图中那样并排排列这些块?

    • 1 个回答
  • Marko Smith

    确定文本文件中每一行的字符数

    • 2 个回答
  • Marko Smith

    将接口对象传递给 JAVA 构造函数

    • 1 个回答
  • Marko Smith

    正确更新数据库中的数据

    • 1 个回答
  • Marko Smith

    Python解析不是css

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5