-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathTree.h
More file actions
117 lines (84 loc) · 2.05 KB
/
Tree.h
File metadata and controls
117 lines (84 loc) · 2.05 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
/*========================================================================*/
/* Huffman Statistic Coding ---- Tree */
/*========================================================================*/
/*========================================================================*/
#include <alloc.h>
/*========================================================================*/
#define _TREE_ 0
#ifndef false
#define false 0
#define true 1
typedef int bool;
#endif
/*========================================================================*/
typedef struct T
{
unsigned char value;
unsigned long count;
struct T *left,*right;
}
Tree;
/*========================================================================*/
bool InitTree ();
Tree *MakeTree ();
Tree *CombineTree (Tree *t1,Tree *t2);
bool DelTree (Tree *t);
bool DeleteTree ();
/*========================================================================*/
Tree *root;
/*========================================================================*/
bool InitTree ()
{
root=NULL; /* alloc.h */
return true;
}
/*========================================================================*/
Tree *MakeTree ()
{
Tree *t;
t=malloc(sizeof(Tree)); /* alloc.h */
if (t)
{
t->value=0;
t->count=0L;
t->left=t->right=NULL; /* alloc.h */
}
return t;
}
/*========================================================================*/
Tree *CombineTree (Tree *t1,Tree *t2)
{
Tree *t;
t=MakeTree();
if (t)
{
t->count=t1->count+t2->count;
t->left=t1;
t->right=t2;
}
return t;
}
/*========================================================================*/
bool DelTree (Tree *t)
{
if (t->left)
{
DelTree(t->left);
t->left=NULL; /* alloc.h */
}
if (t->right)
{
DelTree(t->right);
t->right=NULL; /* alloc.h */
}
if (!t->left && !t->right)
free (t); /* alloc.h */
return true;
}
/*========================================================================*/
bool DeleteTree ()
{
return DelTree(root);
}
/*========================================================================*/