二叉树的最近公共祖先

 1 #include <stdio.h>
 2 
 3 typedef int ElementType;
 4 
 5 struct BinarySearchTreeNode
 6 {
 7     ElementType Element;
 8     struct BinarySearchTreeNode *Left;
 9     struct BinarySearchTreeNode *Right;
10 };
11 
12 //be careful with the names of the node and struct
13 struct BinarySearchTreeNode* BinaryTreeLCA(struct BinarySearchTreeNode* TreeRoot,struct BinarySearchTreeNode* TreeNode_1,struct BinarySearchTreeNode* TreeNode_2)
14 {
15     if(TreeRoot==NULL || TreeRoot==TreeNode_1 || TreeRoot==TreeNode_2)
16     {
17         return TreeRoot;
18     }
19     
20     struct BinarySearchTreeNode* NewLeft = BinaryTreeLCA(TreeRoot -> Left,TreeNode_1,TreeNode_2);
21     struct BinarySearchTreeNode* NewRight = BinaryTreeLCA(TreeRoot -> Right,TreeNode_1,TreeNode_2);
22     
23     if(NewLeft && NewRight)
24     {
25         return TreeRoot;
26     }
27     
28     return NewLeft == NULL ? NewRight : NewLeft;
29 }
30 
31 int main()
32 {
33     //struct BinarySearchTreeNode *TreeNode_1;
34     //struct BinarySearchTreeNode *TreeNode_2;
35     //struct BinarySearchTreeNode *TreeNodeLCA;
36     //TreeNode_1 = BinarySearchTreeNodeFind(2,TreeRoot);
37     //TreeNode_2 = BinarySearchTreeNodeFind(-1,TreeRoot);
38     //TreeNodeLCA = BinaryTreeLCA(TreeRoot,TreeNode_1,TreeNode_2);
39     return 0;
40 }

 

转载于:https://www.cnblogs.com/Asurudo/p/9427483.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值