1 #include"BinaryTree.h"
2
3 // ====================測試代碼====================
4 void Test(char* testName, BinaryTreeNode* pRoot1, BinaryTreeNode* pRoot2, bool expected)
5 {
6 if(HasSubTree(pRoot1, pRoot2) == expected)
7 printf("%s passed.\n", testName);
8 else
9 printf("%s failed.\n", testName);
10 }
11
12 // 樹中結點含有分叉,樹B是樹A的子結構
13 // 8 8
14 // / \ / \
15 // 8 7 9 2
16 // / \
17 // 9 2
18 // / \
19 // 4 7
20 void Test1()
21 {
22 BinaryTreeNode* pNodeA1 = CreateBinaryTreeNode(8);
23 BinaryTreeNode* pNodeA2 = CreateBinaryTreeNode(8);
24 BinaryTreeNode* pNodeA3 = CreateBinaryTreeNode(7);
25 BinaryTreeNode* pNodeA4 = CreateBinaryTreeNode(9);
26 BinaryTreeNode* pNodeA5 = CreateBinaryTreeNode(2);
27 BinaryTreeNode* pNodeA6 = CreateBinaryTreeNode(4);
28 BinaryTreeNode* pNodeA7 = CreateBinaryTreeNode(7);
29
30 ConnectTreeNodes(pNodeA1, pNodeA2, pNodeA3);
31 ConnectTreeNodes(pNodeA2, pNodeA4, pNodeA5);
32 ConnectTreeNodes(pNodeA5, pNodeA6, pNodeA7);
33
34 BinaryTreeNode* pNodeB1 = CreateBinaryTreeNode(8);
35 BinaryTreeNode* pNodeB2 = CreateBinaryTreeNode(9);
36 BinaryTreeNode* pNodeB3 = CreateBinaryTreeNode(2);
37
38 ConnectTreeNodes(pNodeB1, pNodeB2, pNodeB3);
39
40 Test("Test1", pNodeA1, pNodeB1, true);
41
42 DestroyTree(pNodeA1);
43 DestroyTree(pNodeB1);
44 }
45
46 // 樹中結點含有分叉,樹B不是樹A的子結構
47 // 8 8
48 // / \ / \
49 // 8 7 9 2
50 // / \
51 // 9 3
52 // / \
53 // 4 7
54 void Test2()
55 {
56 BinaryTreeNode* pNodeA1 = CreateBinaryTreeNode(8);
57 BinaryTreeNode* pNodeA2 = CreateBinaryTreeNode(8);
58 BinaryTreeNode* pNodeA3 = CreateBinaryTreeNode(7);
59 BinaryTreeNode* pNodeA4 = CreateBinaryTreeNode(9);
60 BinaryTreeNode* pNodeA5 = CreateBinaryTreeNode(3);
61 BinaryTreeNode* pNodeA6 = CreateBinaryTreeNode(4);
62 BinaryTreeNode* pNodeA7 = CreateBinaryTreeNode(7);
63
64 ConnectTreeNodes(pNodeA1, pNodeA2, pNodeA3);
65 ConnectTreeNodes(pNodeA2, pNodeA4, pNodeA5);
66 ConnectTreeNodes(pNodeA5, pNodeA6, pNodeA7);
67
68 BinaryTreeNode* pNodeB1 = CreateBinaryTreeNode(8);
69 BinaryTreeNode* pNodeB2 = CreateBinaryTreeNode(9);
70 BinaryTreeNode* pNodeB3 = CreateBinaryTreeNode(2);
71
72 ConnectTreeNodes(pNodeB1, pNodeB2, pNodeB3);
73
74 Test("Test2", pNodeA1, pNodeB1, false);
75
76 DestroyTree(pNodeA1);
77 DestroyTree(pNodeB1);
78 }
79
80 // 樹中結點只有左子結點,樹B是樹A的子結構
81 // 8 8
82 // / /
83 // 8 9
84 // / /
85 // 9 2
86 // /
87 // 2
88 // /
89 // 5
90 void Test3()
91 {
92 BinaryTreeNode* pNodeA1 = CreateBinaryTreeNode(8);
93 BinaryTreeNode* pNodeA2 = CreateBinaryTreeNode(8);
94 BinaryTreeNode* pNodeA3 = CreateBinaryTreeNode(9);
95 BinaryTreeNode* pNodeA4 = CreateBinaryTreeNode(2);
96 BinaryTreeNode* pNodeA5 = CreateBinaryTreeNode(5);
97
98 ConnectTreeNodes(pNodeA1, pNodeA2, nullptr);
99 ConnectTreeNodes(pNodeA2, pNodeA3, nullptr);
100 ConnectTreeNodes(pNodeA3, pNodeA4, nullptr);
101 ConnectTreeNodes(pNodeA4, pNodeA5, nullptr);
102
103 BinaryTreeNode* pNodeB1 = CreateBinaryTreeNode(8);
104 BinaryTreeNode* pNodeB2 = CreateBinaryTreeNode(9);
105 BinaryTreeNode* pNodeB3 = CreateBinaryTreeNode(2);
106
107 ConnectTreeNodes(pNodeB1, pNodeB2, nullptr);
108 ConnectTreeNodes(pNodeB2, pNodeB3, nullptr);
109
110 Test("Test3", pNodeA1, pNodeB1, true);
111
112 DestroyTree(pNodeA1);
113 DestroyTree(pNodeB1);
114 }
115
116 // 樹中結點只有左子結點,樹B不是樹A的子結構
117 // 8 8
118 // / /
119 // 8 9
120 // / /
121 // 9 3
122 // /
123 // 2
124 // /
125 // 5
126 void Test4()
127 {
128 BinaryTreeNode* pNodeA1 = CreateBinaryTreeNode(8);
129 BinaryTreeNode* pNodeA2 = CreateBinaryTreeNode(8);
130 BinaryTreeNode* pNodeA3 = CreateBinaryTreeNode(9);
131 BinaryTreeNode* pNodeA4 = CreateBinaryTreeNode(2);
132 BinaryTreeNode* pNodeA5 = CreateBinaryTreeNode(5);
133
134 ConnectTreeNodes(pNodeA1, pNodeA2, nullptr);
135 ConnectTreeNodes(pNodeA2, pNodeA3, nullptr);
136 ConnectTreeNodes(pNodeA3, pNodeA4, nullptr);
137 ConnectTreeNodes(pNodeA4, pNodeA5, nullptr);
138
139 BinaryTreeNode* pNodeB1 = CreateBinaryTreeNode(8);
140 BinaryTreeNode* pNodeB2 = CreateBinaryTreeNode(9);
141 BinaryTreeNode* pNodeB3 = CreateBinaryTreeNode(3);
142
143 ConnectTreeNodes(pNodeB1, pNodeB2, nullptr);
144 ConnectTreeNodes(pNodeB2, pNodeB3, nullptr);
145
146 Test("Test4", pNodeA1, pNodeB1, false);
147
148 DestroyTree(pNodeA1);
149 DestroyTree(pNodeB1);
150 }
151
152 // 樹中結點只有右子結點,樹B是樹A的子結構
153 // 8 8
154 // \ \
155 // 8 9
156 // \ \
157 // 9 2
158 // \
159 // 2
160 // \
161 // 5
162 void Test5()
163 {
164 BinaryTreeNode* pNodeA1 = CreateBinaryTreeNode(8);
165 BinaryTreeNode* pNodeA2 = CreateBinaryTreeNode(8);
166 BinaryTreeNode* pNodeA3 = CreateBinaryTreeNode(9);
167 BinaryTreeNode* pNodeA4 = CreateBinaryTreeNode(2);
168 BinaryTreeNode* pNodeA5 = CreateBinaryTreeNode(5);
169
170 ConnectTreeNodes(pNodeA1, nullptr, pNodeA2);
171 ConnectTreeNodes(pNodeA2, nullptr, pNodeA3);
172 ConnectTreeNodes(pNodeA3, nullptr, pNodeA4);
173 ConnectTreeNodes(pNodeA4, nullptr, pNodeA5);
174
175 BinaryTreeNode* pNodeB1 = CreateBinaryTreeNode(8);
176 BinaryTreeNode* pNodeB2 = CreateBinaryTreeNode(9);
177 BinaryTreeNode* pNodeB3 = CreateBinaryTreeNode(2);
178
179 ConnectTreeNodes(pNodeB1, nullptr, pNodeB2);
180 ConnectTreeNodes(pNodeB2, nullptr, pNodeB3);
181
182 Test("Test5", pNodeA1, pNodeB1, true);
183
184 DestroyTree(pNodeA1);
185 DestroyTree(pNodeB1);
186 }
187
188 // 樹A中結點只有右子結點,樹B不是樹A的子結構
189 // 8 8
190 // \ \
191 // 8 9
192 // \ / \
193 // 9 3 2
194 // \
195 // 2
196 // \
197 // 5
198 void Test6()
199 {
200 BinaryTreeNode* pNodeA1 = CreateBinaryTreeNode(8);
201 BinaryTreeNode* pNodeA2 = CreateBinaryTreeNode(8);
202 BinaryTreeNode* pNodeA3 = CreateBinaryTreeNode(9);
203 BinaryTreeNode* pNodeA4 = CreateBinaryTreeNode(2);
204 BinaryTreeNode* pNodeA5 = CreateBinaryTreeNode(5);
205
206 ConnectTreeNodes(pNodeA1, nullptr, pNodeA2);
207 ConnectTreeNodes(pNodeA2, nullptr, pNodeA3);
208 ConnectTreeNodes(pNodeA3, nullptr, pNodeA4);
209 ConnectTreeNodes(pNodeA4, nullptr, pNodeA5);
210
211 BinaryTreeNode* pNodeB1 = CreateBinaryTreeNode(8);
212 BinaryTreeNode* pNodeB2 = CreateBinaryTreeNode(9);
213 BinaryTreeNode* pNodeB3 = CreateBinaryTreeNode(3);
214 BinaryTreeNode* pNodeB4 = CreateBinaryTreeNode(2);
215
216 ConnectTreeNodes(pNodeB1, nullptr, pNodeB2);
217 ConnectTreeNodes(pNodeB2, pNodeB3, pNodeB4);
218
219 Test("Test6", pNodeA1, pNodeB1, false);
220
221 DestroyTree(pNodeA1);
222 DestroyTree(pNodeB1);
223 }
224
225 // 樹A爲空樹
226 void Test7()
227 {
228 BinaryTreeNode* pNodeB1 = CreateBinaryTreeNode(8);
229 BinaryTreeNode* pNodeB2 = CreateBinaryTreeNode(9);
230 BinaryTreeNode* pNodeB3 = CreateBinaryTreeNode(3);
231 BinaryTreeNode* pNodeB4 = CreateBinaryTreeNode(2);
232
233 ConnectTreeNodes(pNodeB1, nullptr, pNodeB2);
234 ConnectTreeNodes(pNodeB2, pNodeB3, pNodeB4);
235
236 Test("Test7", nullptr, pNodeB1, false);
237
238 DestroyTree(pNodeB1);
239 }
240
241 // 樹B爲空樹
242 void Test8()
243 {
244 BinaryTreeNode* pNodeA1 = CreateBinaryTreeNode(8);
245 BinaryTreeNode* pNodeA2 = CreateBinaryTreeNode(9);
246 BinaryTreeNode* pNodeA3 = CreateBinaryTreeNode(3);
247 BinaryTreeNode* pNodeA4 = CreateBinaryTreeNode(2);
248
249 ConnectTreeNodes(pNodeA1, nullptr, pNodeA2);
250 ConnectTreeNodes(pNodeA2, pNodeA3, pNodeA4);
251
252 Test("Test8", pNodeA1, nullptr, false);
253
254 DestroyTree(pNodeA1);
255 }
256
257 // 樹A和樹B都爲空
258 void Test9()
259 {
260 Test("Test9", nullptr, nullptr, false);
261 }
262
263 int main(int argc, char* argv[])
264 {
265 Test1();
266 Test2();
267 Test3();
268 Test4();
269 Test5();
270 Test6();
271 Test7();
272 Test8();
273 Test9();
274
275 return 0;
276 }