189 8069 5689

golang中怎么利用leetcode实现一个合法二叉搜索树

这篇文章将为大家详细讲解有关golang中怎么利用leetcode实现一个合法二叉搜索树,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

10年积累的网站设计制作、成都网站设计经验,可以快速应对客户对网站的新想法和需求。提供各种问题对应的解决方案。让选择我们的客户得到更好、更有力的网络服务。我虽然不认识你,你也不认识我。但先网站制作后付款的网站建设流程,更有辰溪免费网站建设让你可以放心的选择与我们合作。

实现一个函数,检查一棵二叉树是否为二叉搜索树。

示例 1:

输入:
   2
  / \
 1   3
输出: true

示例 2:

输入:
   5
  / \
 1   4
     / \
    3   6
输出: false
解释: 输入为: [5,1,4,null,null,3,6]。
     根节点的值为 5 ,但是其右子节点值为 4 。

解题思路

1,如果没有叶子节点返回true

2,如果左子树非空,需要返回前缀节点路径上的最大值,且比根节点小

3,如果右子树非空,需要返回后缀节点路径上的最小值,且比根节点大

4,左右子树都是合法的

5,需要注意,不是前缀节点是前缀节点路径最大值

测试用例

[5,1,4,null,null,3,6]

[5,14,null,1]

代码实现

/** * Definition for a binary tree node. * type TreeNode struct { *     Val int *     Left *TreeNode *     Right *TreeNode * } */func isValidBST(root *TreeNode) bool {   if root==nil || (root.Left==nil && root.Right==nil) {       return true   }
  valid:=true   if root.Left!=nil{      l:=pre(root.Left)      if l>=root.Val{          valid=false      }      fmt.Println(l,root)   }   if root.Right!=nil{      r:=suc(root.Right)      if r<=root.Val{          valid=false      }       fmt.Println(r,root)   }   return valid && isValidBST(root.Left) && isValidBST(root.Right)}
func pre(root * TreeNode) int{    //root !=nil    max:=root.Val    cur:=root    for cur!=nil{        if cur.Right!=nil{            cur=cur.Right            if max            max=cur.Val            }        }else{            cur=cur.Left            if cur!=nil && max                max=cur.Val            }        }    }    return max}
func suc(root*TreeNode)int{     min:=root.Val    cur:=root    for cur!=nil{        if cur.Left!=nil{            cur=cur.Left            if min >cur.Val{            min=cur.Val            }        }else{            cur=cur.Right            if cur!=nil &&  min >cur.Val{                min=cur.Val            }        }    }    return min}

关于golang中怎么利用leetcode实现一个合法二叉搜索树就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。


文章标题:golang中怎么利用leetcode实现一个合法二叉搜索树
标题来源:http://cdxtjz.cn/article/gspdhj.html

联系我们

您好HELLO!
感谢您来到成都网站建设公司,若您有合作意向,请您为我们留言或使用以下方式联系我们, 我们将尽快给你回复,并为您提供真诚的设计服务,谢谢。
  • 电话:028- 86922220 18980695689
  • 商务合作邮箱:631063699@qq.com
  • 合作QQ: 532337155
  • 成都网站设计地址:成都市青羊区锣锅巷31号五金站写字楼6楼

小谭建站工作室

成都小谭网站建设公司拥有多年以上互联网从业经验的团队,始终保持务实的风格,以"帮助客户成功"为已任,专注于提供对客户有价值的服务。 我们已为众企业及上市公司提供专业的网站建设服务。我们不只是一家网站建设的网络公司;我们对营销、技术、管理都有自己独特见解,小谭建站采取“创意+综合+营销”一体化的方式为您提供更专业的服务!

小谭观点

相对传统的成都网站建设公司而言,小谭是互联网中的网站品牌策划,我们精于企业品牌与互联网相结合的整体战略服务。
我们始终认为,网站必须注入企业基因,真正使网站成为企业vi的一部分,让整个网站品牌策划体系变的深入而持久。