代码随想录算法训练营第二十二天|235. 二叉搜索树的最近公共祖先、701.二叉搜索树中的插入操作

代码随想录算法训练营第二十二天|235. 二叉搜索树的最近公共祖先、701.二叉搜索树中的插入操作

    • 235. 二叉搜索树的最近公共祖先
      • 思路
      • 解题代码
    • 701.二叉搜索树中的插入操作
      • 思路
      • 解题代码
    • 450.删除二叉搜索树中的节点
      • 思路
      • 解题代码

235. 二叉搜索树的最近公共祖先

题目链接:235. 二叉搜索树的最近公共祖先

思路

利用二叉搜索树的有序性,迭代解题。

解题代码

func lowestCommonAncestor(root, p, q *TreeNode) *TreeNode {
	if root == nil {
        return nil
    }
    for {
         if root.Val > p.Val && root.Val > q.Val {
            root = root.Left
    	}
        if root.Val < p.Val && root.Val < q.Val {
            root = root.Right
        }
        if (root.Val - p.Val) * (root.Val - q.Val) <= 0 {
            return root
        }
    }
        return root
}

701.二叉搜索树中的插入操作

题目链接:701.二叉搜索树中的插入操作

思路

比较大小,比节点小递归左边,比节点大递归右边,递归到最底层就生成新节点。

解题代码

/**
 * Definition for a binary tree node.
 * type TreeNode struct {
 *     Val int
 *     Left *TreeNode
 *     Right *TreeNode
 * }
 */
func insertIntoBST(root *TreeNode, val int) *TreeNode {
    if root == nil {
        root = &TreeNode{Val: val}
        return root
    }
    if root.Val > val {
        root.Left = insertIntoBST(root.Left, val)
    } else {
        root.Right = insertIntoBST(root.Right, val)
    }
    return root
}

450.删除二叉搜索树中的节点

题目链接:450.删除二叉搜索树中的节点

思路

二刷加强

解题代码

/**
 * Definition for a binary tree node.
 * type TreeNode struct {
 *     Val int
 *     Left *TreeNode
 *     Right *TreeNode
 * }
 */
func deleteNode(root *TreeNode, key int) *TreeNode {
    if root == nil {
        return nil
    }
    if key < root.Val {
        root.Left = deleteNode(root.Left, key)  //左
        return root
    }
    if key > root.Val {
        root.Right = deleteNode(root.Right, key)  //右
        return root
    }
    if root.Right == nil {
        return root.Left
    }
    if root.Left == nil{
        return root.Right
    }
    minnode := root.Right
    for minnode.Left != nil {
        minnode = minnode.Left
    }
    root.Val = minnode.Val
    root.Right = deleteNode1(root.Right)
    return root
}

func deleteNode1(root *TreeNode)*TreeNode {
    if root.Left == nil {
        pRight := root.Right
        root.Right = nil
        return pRight
    }
    root.Left = deleteNode1(root.Left)
    return root
}

你可能感兴趣的:(代码随想录训练营,算法,leetcode,职场和发展)