还是前面那个题,同学去阿里面试的时候,要求写出代码:
现在有一棵二叉排序树,每个节点保存一个int类型的值,删除值为10以下的节点(树中可能不含值为10的节点),说一下思路,写一下算法。
算了原来错误的思路就不拿出来误导大家了,只能说想简单了,花了几天空闲的时间思考这个问题,终于把代码写出来了,虽然琢磨了一段时间,但是终究还是写出来了。经过测试数据或者自己画图,感觉有这么几个难点把
1.如果数据是这样:6,5,7,8,15,就是先开始根结点的值小于10,后来右子树中=存在大于10的结点,由于需要释放小于10的结点,就需要重新调整根结点
2.如果数据是这样:6,5,7,8,15,14,9,8,13,11,10,就是先开始小于10ÿ