博客
关于我
leetcode——数组构造二叉树问题
阅读量:330 次
发布时间:2019-03-04

本文共 857 字,大约阅读时间需要 2 分钟。

有序数组转变二叉搜索树

有序数组转换为二叉搜索树的过程中,选择中间位置的元素作为根节点可能会导致树的结构不符合二叉搜索树的定义。正确的二叉搜索树应该遵循插入顺序的特性,根节点应该是第一个插入的元素。

代码分析

  • helper方法:总是选择中间位置的元素作为根节点,这可能不符合二叉搜索树的定义。正确的做法应该是选择插入的第一个元素作为根节点。
  • 递归终止条件left > right 是正确的终止条件,但需要确认递归路径是否正确。
  • 递归调用:左子树和右子树的递归调用范围计算正确。

优化建议

  • 修改根节点的选择逻辑,选择插入顺序的第一个元素作为根节点。
  • 确保递归调用正确地处理所有可能的子数组。
  • 前中序数组构造二叉树

    使用前序和中序数组构造二叉树的方法是正确的,因为前序数组的第一个元素作为根节点,中序数组可以帮助确定左子树和右子树的范围。

    代码分析

    • 哈希表:正确地存储了中序数组的值,方便快速查找。
    • 递归构建:左子树和右子树的递归调用范围计算正确。
    • 递归终止条件preLeft > preRightinLeft > inRight 是正确的。

    优化建议

  • 确保递归调用中左子树和右子树的范围计算准确,避免越界。
  • 可以考虑使用更高效的方式查找根节点的位置,减少哈希表的使用。
  • 中后序数组构造二叉树

    使用前序和后序数组构造二叉树的方法较为复杂,但可行性存在争议,因为前序和后序数组通常不会同时存在,且构造过程较为复杂。

    代码分析

    • 哈希表:正确地存储了中序数组的值,方便快速查找。
    • 递归构建:左子树和右子树的递归调用范围计算正确。
    • 递归终止条件preLeft > preRightinLeft > inRight 是正确的。

    优化建议

  • 可能需要重新审视前序和后序数组的作用,确保它们的有效性。
  • 优化递归调用中的索引计算,避免错误。
  • 总结

    这些代码片段展示了如何将不同类型的数组遍历转换为二叉树,但每个实现都有其特定的挑战和优化空间。通过仔细分析代码逻辑,可以发现并修复潜在的错误,从而提高代码的正确性和效率。

    转载地址:http://gwjh.baihongyu.com/

    你可能感兴趣的文章
    Objective-C实现entropy熵算法(附完整源码)
    查看>>
    Objective-C实现euclidean distance欧式距离算法(附完整源码)
    查看>>
    Objective-C实现euclideanDistance欧氏距离算法(附完整源码)
    查看>>
    Objective-C实现euler method欧拉法算法(附完整源码)
    查看>>
    Objective-C实现eulerianPath欧拉路径算法(附完整源码)
    查看>>
    Objective-C实现eval函数功能(附完整源码)
    查看>>
    Objective-C实现Exceeding words超词(差距是ascii码的距离) 算法(附完整源码)
    查看>>
    Objective-C实现extended euclidean algorithm扩展欧几里得算法(附完整源码)
    查看>>
    Objective-C实现factorial iterative阶乘迭代算法(附完整源码)
    查看>>
    Objective-C实现FigurateNumber垛积数算法(附完整源码)
    查看>>
    Objective-C实现Gale-Shapley盖尔-沙普利算法(附完整源码)
    查看>>
    Objective-C实现hamming numbers汉明数算法(附完整源码)
    查看>>
    Objective-C实现hanoiTower汉诺塔算法(附完整源码)
    查看>>
    Objective-C实现hardy ramanujana定理算法(附完整源码)
    查看>>
    Objective-C实现highest response ratio next高响应比优先调度算法(附完整源码)
    查看>>
    Objective-C实现hill climbing爬山法用来寻找函数的最大值算法(附完整源码)
    查看>>
    Objective-C实现hornerMethod霍纳法算法(附完整源码)
    查看>>
    Objective-C实现Http Post请求(附完整源码)
    查看>>
    Objective-C实现Http协议下载文件(附完整源码)
    查看>>
    Objective-C实现IIR 滤波器算法(附完整源码)
    查看>>