package tree;
import sun.reflect.generics.tree.Tree;
import java.util.ArrayList;
import java.util.List;
/**
 * 450. 删除二叉搜索树中的节点
 * 给定一个二叉搜索树的根节点 root 和一个值 key,删除二叉搜索树中的 key 对应的节点,并保证二叉搜索树的性质不变。返回二叉搜索树(有可能被更新)的根节点的引用。
 *
 * 一般来说,删除节点可分为两个步骤:
 *
 * 首先找到需要删除的节点;
 * 如果找到了,删除它。
 *
 *
 * @author Tang
 * @date 2021/7/27
 */
public class DeleteNode {
    List<TreeNode> list = new ArrayList<>();
    public TreeNode deleteNode(TreeNode root, int key) {
        if(root == null){
            return null;
        }
        //中序遍历将各节点顺序加入到链表
        midSearch(root);
        //干掉key相等的节点
        TreeNode temp = null;
        for (TreeNode node : list) {
            if(node.val == key){
                temp = node;
            }
        }
        if(temp != null){
            list.remove(temp);
        }
        //重新构造二叉搜索树
        return preSearch(list);
    }
    /**
     * 中序遍历,将所有节点顺序加入链表
     *
     */
    public void midSearch(TreeNode root) {
        if(root == null){
            return;
        }
        midSearch(root.left);
        list.add(root);
        midSearch(root.right);
    }
    /**
     * 前序遍历,将链表重新构造成一棵二叉搜索树
     */
    public TreeNode preSearch(List<TreeNode> list){
        if(list == null || list.size() == 0){
            return null;
        }
        int mid = list.size() / 2;
        TreeNode node = list.get(mid);
        node.left = preSearch(list.subList(0, mid));
        node.right = preSearch(list.subList(mid+1, list.size()));
        return node;
    }
    public static void main(String[] args) {
        TreeNode node1 = new TreeNode(5);
        TreeNode node2 = new TreeNode(3);
        TreeNode node3 = new TreeNode(6);
        TreeNode node4 = new TreeNode(2);
        TreeNode node5 = new TreeNode(4);
        TreeNode node6 = new TreeNode(7);
        node1.left = node2;
        node1.right = node3;
        node2.left = node4;
        node2.right = node5;
        node3.right = node6;
        new DeleteNode().deleteNode(node1, 3);
    }
}