2021-03-21:给定一棵二叉树的头节点head,求以head为头的树中,最小深度是多少?

福大大 答案2021-03-21:

1.递归。
2.莫里斯遍历。

代码用golang编写,代码如下:

package mainimport "fmt"func main() {    head := &TreeNode{}    head.Left = &TreeNode{}    head.Right = &TreeNode{}    head.Right.Right = &TreeNode{}    ret := minHeight1(head)    fmt.Println("1.递归:", ret)    ret = minHeight2(head)    fmt.Println("2.莫里斯遍历:", ret)}//Definition for a binary tree node.type TreeNode struct {    Val   int    Left  *TreeNode    Right *TreeNode}const INT_MAX = int(^uint(0) >> 1)func minHeight1(head *TreeNode) int {    if head == nil {        return 0    }    leftVal := minHeight1(head.Left)    rightVal := minHeight1(head.Right)    return 1 + getMin(leftVal, rightVal)}// 根据morris遍历改写func minHeight2(head *TreeNode) int {    if head == nil {        return 0    }    cur := head    var mostRight *TreeNode    curLevel := 0    minHeight := INT_MAX    for cur != nil {        mostRight = cur.Left        if mostRight != nil {            rightBoardSize := 1            for mostRight.Right != nil && mostRight.Right != cur {                rightBoardSize++                mostRight = mostRight.Right            }            if mostRight.Right == nil { // 第一次到达                curLevel++                mostRight.Right = cur                cur = cur.Left                continue            } else { // 第二次到达                if mostRight.Left == nil {                    minHeight = getMin(minHeight, curLevel)                }                curLevel -= rightBoardSize                mostRight.Right = nil            }        } else { // 只有一次到达            curLevel++        }        cur = cur.Right    }    finalRight := 1    cur = head    for cur.Right != nil {        finalRight++        cur = cur.Right    }    if cur.Left == nil && cur.Right == nil {        minHeight = getMin(minHeight, finalRight)    }    return minHeight}func getMin(a int, b int) int {    if a < b {        return a    } else {        return b    }}

执行结果如下:


左神java代码
评论

©著作权归作者所有:来自51CTO博客作者福大大的原创作品,如需转载,请注明出处,否则将追究法律责任

你的鼓励让我更有动力

赞赏

0人进行了赞赏支持

更多相关文章

  1. Influxdb中Select查询请求结果涉及到的一些数据结构
  2. 面试题:为什么Java中的Collection类都继承了抽象类还要实现抽象类
  3. 每天5道linux面试题(第一天)
  4. ORA-00069: cannot acquire lock
  5. 循环单链表及常用操作(C语言描述)
  6. 2021-03-16:手写代码:单链表归并排序。
  7. ThinkPHP框架:数据库链表查询和导航渲染(导航数据递归生成)
  8. 3-15(二叉树的算法题)
  9. Python将一个数逆序列放入列表中

随机推荐

  1. Android: Android NDK Overview
  2. Android 内存泄漏场景分析
  3. Android android:persistentDrawingCache
  4. Android 短信发送器
  5. Android7.0中文文档(API)-- ShareActionPro
  6. AndroidStudio使用教程(第一弹)
  7. Cocos2d-x C++调用Android弹出提示框
  8. Android 麦克风录音动画
  9. json解析android客户端源码
  10. 不错的Android开发资料,收藏一下