伍佰目录 短网址
  当前位置:海洋目录网 » 站长资讯 » 站长资讯 » 文章详细 订阅RssFeed

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

来源:本站原创 浏览:87次 时间:2022-06-01

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代码
评论

  推荐站点

  • At-lib分类目录At-lib分类目录

    At-lib网站分类目录汇集全国所有高质量网站,是中国权威的中文网站分类目录,给站长提供免费网址目录提交收录和推荐最新最全的优秀网站大全是名站导航之家

    www.at-lib.cn
  • 中国链接目录中国链接目录

    中国链接目录简称链接目录,是收录优秀网站和淘宝网店的网站分类目录,为您提供优质的网址导航服务,也是网店进行收录推广,站长免费推广网站、加快百度收录、增加友情链接和网站外链的平台。

    www.cnlink.org
  • 35目录网35目录网

    35目录免费收录各类优秀网站,全力打造互动式网站目录,提供网站分类目录检索,关键字搜索功能。欢迎您向35目录推荐、提交优秀网站。

    www.35mulu.com
  • 就要爱网站目录就要爱网站目录

    就要爱网站目录,按主题和类别列出网站。所有提交的网站都经过人工审查,确保质量和无垃圾邮件的结果。

    www.912219.com
  • 伍佰目录伍佰目录

    伍佰网站目录免费收录各类优秀网站,全力打造互动式网站目录,提供网站分类目录检索,关键字搜索功能。欢迎您向伍佰目录推荐、提交优秀网站。

    www.wbwb.net