summaryrefslogtreecommitdiff
path: root/btree-str.c
diff options
context:
space:
mode:
Diffstat (limited to 'btree-str.c')
-rw-r--r--btree-str.c15
1 files changed, 15 insertions, 0 deletions
diff --git a/btree-str.c b/btree-str.c
index 3f080a4..539f03a 100644
--- a/btree-str.c
+++ b/btree-str.c
@@ -10,6 +10,7 @@ typedef struct Node {
void an(Node **, Node *);
void pn(Node *);
+void fn(Node *);
void an(Node **r, Node *n) {
if (!*r) {
@@ -38,6 +39,18 @@ void pn(Node *n) {
return;
}
+void fn(Node *n) {
+ if (!n) {
+ return;
+ }
+ if (n->l)
+ fn(n->l);
+ if (n->r)
+ fn(n->r);
+ free(n);
+ return;
+}
+
int main(int argc, char **argv) {
Node *r = NULL;
@@ -50,5 +63,7 @@ int main(int argc, char **argv) {
pn(r);
+ fn(r);
+
exit(EXIT_SUCCESS);
}