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

发布时间:2021-07-06 15:04:58 作者:Leah
来源:亿速云 阅读:123

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

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

示例 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<cur.Val{            max=cur.Val            }        }else{            cur=cur.Left            if cur!=nil && max<cur.Val{                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实现一个合法二叉搜索树就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

推荐阅读:
  1. golang中怎么利用leetcode 实现一个任务调度器
  2. golang中怎么利用leetcode 恢复二叉搜索树

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

golang leetcode

上一篇:golang中怎么利用leetcode 实现链表求和

下一篇:Golang中sort包的作用是什么

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》