首先我们定义以下二叉树的数据结构,通过结构体定义,代码如下:
struct Tree {
int n;
struct Tree* p;
struct Tree* left;
struct Tree* right;
};
struct BinaryTree {
struct Tree* root;
};
为了完成深度优先搜索,我们需要借助于栈结构。包括压栈,出栈操作,基于数组实现。代码如下:
struct Stack {
struct Tree a[20];
int maxIndex; //栈顶元素的下标,初始为-1
};
void push(struct Stack* s, struct Tree node) {
if (s->maxIndex >= 19) {
printf("Stack has no room!\n");
return;
}
s->maxIndex++;
s->a[s->maxIndex] = node;
}
struct Tree pop(struct Stack* s) {
if (s->maxIndex < 0) {
printf("Stack has no node!\n");
exit(0);
}
s->maxIndex--;
return s->a[s->maxIndex + 1];
}
接下来便是对树进行遍历的代码,我们采用深度优先搜索:先将根节点压入栈中。对栈中的节点循环进行以下操作:每次将栈顶元素出栈,打印该元素内容,并且将其右子数根节点,左子树根节点(如果有)分别压栈。循环以下操作,直到