JZ-C-50

劍指offer第五十題:樹中兩個結點的最低公共祖先:這裏的樹是普通樹,且沒有指向父結點的指針。ios

  1 //============================================================================
  2 // Name        : JZ-C-50.cpp
  3 // Author      : Laughing_Lz
  4 // Version     :
  5 // Copyright   : All Right Reserved
  6 // Description : 樹中兩個結點的最低公共祖先:這裏的樹是普通樹,且沒有指向父結點的指針。
  7 //============================================================================
  8 
  9 #include <iostream>
 10 #include <stdio.h>
 11 #include "Tree.h"
 12 #include <list>
 13 using namespace std;
 14 
 15 using namespace std;
 16 /**
 17  * 得到從樹的根結點到某結點的路徑
 18  */
 19 bool GetNodePath(TreeNode* pRoot, TreeNode* pNode, list<TreeNode*>& path) {
 20     if (pRoot == pNode)
 21         return true;
 22 
 23     path.push_back(pRoot);
 24 
 25     bool found = false;
 26 
 27     vector<TreeNode*>::iterator i = pRoot->m_vChildren.begin(); //這裏的樹爲普通樹,甚至不是二叉樹。因此這裏按照前序遍歷子樹便可。
 28     while (!found && i < pRoot->m_vChildren.end()) {
 29         found = GetNodePath(*i, pNode, path);
 30         ++i;
 31     }
 32 
 33     if (!found)
 34         path.pop_back();
 35 
 36     return found;
 37 }
 38 /**
 39  * 得到兩條路徑的最後一個公共結點。
 40  */
 41 TreeNode* GetLastCommonNode(const list<TreeNode*>& path1,
 42         const list<TreeNode*>& path2) {
 43     list<TreeNode*>::const_iterator iterator1 = path1.begin();
 44     list<TreeNode*>::const_iterator iterator2 = path2.begin();
 45 
 46     TreeNode* pLast = NULL;
 47 
 48     while (iterator1 != path1.end() && iterator2 != path2.end()) {
 49         if (*iterator1 == *iterator2)
 50             pLast = *iterator1; //遍歷完兩條路徑,獲得最後一個公共結點。
 51 
 52         iterator1++;
 53         iterator2++;
 54     }
 55 
 56     return pLast;
 57 }
 58 
 59 TreeNode* GetLastCommonParent(TreeNode* pRoot, TreeNode* pNode1,
 60         TreeNode* pNode2) {
 61     if (pRoot == NULL || pNode1 == NULL || pNode2 == NULL)
 62         return NULL;
 63 
 64     list<TreeNode*> path1;
 65     GetNodePath(pRoot, pNode1, path1);
 66 
 67     list<TreeNode*> path2;
 68     GetNodePath(pRoot, pNode2, path2);
 69 
 70     return GetLastCommonNode(path1, path2);
 71 }
 72 
 73 // ====================測試代碼====================
 74 
 75 void Test(char* testName, TreeNode* pRoot, TreeNode* pNode1, TreeNode* pNode2,
 76         TreeNode* pExpected) {
 77     if (testName != NULL)
 78         printf("%s begins: \n", testName);
 79 
 80     TreeNode* pResult = GetLastCommonParent(pRoot, pNode1, pNode2);
 81 
 82     if ((pExpected == NULL && pResult == NULL)
 83             || (pExpected != NULL && pResult != NULL
 84                     && pResult->m_nValue == pExpected->m_nValue))
 85         printf("Passed.\n");
 86     else
 87         printf("Failed.\n");
 88 }
 89 
 90 // 形狀普通的樹
 91 //              1
 92 //            /   \
 93 //           2     3
 94 //       /       \
 95 //      4         5
 96 //     / \      / |  \
 97 //    6   7    8  9  10
 98 void Test1() {
 99     TreeNode* pNode1 = CreateTreeNode(1);
100     TreeNode* pNode2 = CreateTreeNode(2);
101     TreeNode* pNode3 = CreateTreeNode(3);
102     TreeNode* pNode4 = CreateTreeNode(4);
103     TreeNode* pNode5 = CreateTreeNode(5);
104     TreeNode* pNode6 = CreateTreeNode(6);
105     TreeNode* pNode7 = CreateTreeNode(7);
106     TreeNode* pNode8 = CreateTreeNode(8);
107     TreeNode* pNode9 = CreateTreeNode(9);
108     TreeNode* pNode10 = CreateTreeNode(10);
109 
110     ConnectTreeNodes(pNode1, pNode2);
111     ConnectTreeNodes(pNode1, pNode3);
112 
113     ConnectTreeNodes(pNode2, pNode4);
114     ConnectTreeNodes(pNode2, pNode5);
115 
116     ConnectTreeNodes(pNode4, pNode6);
117     ConnectTreeNodes(pNode4, pNode7);
118 
119     ConnectTreeNodes(pNode5, pNode8);
120     ConnectTreeNodes(pNode5, pNode9);
121     ConnectTreeNodes(pNode5, pNode10);
122 
123     Test("Test1", pNode1, pNode6, pNode8, pNode2);
124 }
125 
126 // 樹退化成一個鏈表
127 //               1
128 //              /
129 //             2
130 //            /
131 //           3
132 //          /
133 //         4
134 //        /
135 //       5
136 void Test2() {
137     TreeNode* pNode1 = CreateTreeNode(1);
138     TreeNode* pNode2 = CreateTreeNode(2);
139     TreeNode* pNode3 = CreateTreeNode(3);
140     TreeNode* pNode4 = CreateTreeNode(4);
141     TreeNode* pNode5 = CreateTreeNode(5);
142 
143     ConnectTreeNodes(pNode1, pNode2);
144     ConnectTreeNodes(pNode2, pNode3);
145     ConnectTreeNodes(pNode3, pNode4);
146     ConnectTreeNodes(pNode4, pNode5);
147 
148     Test("Test2", pNode1, pNode5, pNode4, pNode3);
149 }
150 
151 // 樹退化成一個鏈表,一個結點不在樹中
152 //               1
153 //              /
154 //             2
155 //            /
156 //           3
157 //          /
158 //         4
159 //        /
160 //       5
161 void Test3() {
162     TreeNode* pNode1 = CreateTreeNode(1);
163     TreeNode* pNode2 = CreateTreeNode(2);
164     TreeNode* pNode3 = CreateTreeNode(3);
165     TreeNode* pNode4 = CreateTreeNode(4);
166     TreeNode* pNode5 = CreateTreeNode(5);
167 
168     ConnectTreeNodes(pNode1, pNode2);
169     ConnectTreeNodes(pNode2, pNode3);
170     ConnectTreeNodes(pNode3, pNode4);
171     ConnectTreeNodes(pNode4, pNode5);
172 
173     TreeNode* pNode6 = CreateTreeNode(6);
174 
175     Test("Test3", pNode1, pNode5, pNode6, NULL);
176 }
177 
178 // 輸入NULL
179 void Test4() {
180     Test("Test4", NULL, NULL, NULL, NULL);
181 }
182 
183 int main(int argc, char** argv) {
184     Test1();
185     Test2();
186     Test3();
187     Test4();
188 
189     return 0;
190 }
相關文章
相關標籤/搜索
本站公眾號
   歡迎關注本站公眾號,獲取更多信息