二叉树遍历的6种遍历方法(先序遍历,中序遍历,后序遍历分别用递归跟非递归实现)。
主要代码如下:
#include <stdlib.h>
#define TRUE 1
#define FALSE 0
#define OK 1
#define ERROR 0
#define INFEASIBLE -1
#define OVERFLOW -2
typedef struct BiTNode
{
int data;
struct BiTNode *left,*right;
}BiTNode,*BiTree;
int visit(int a)
{
printf(a);
return OK;
}
//先序遍历--递归
int PreOrder(BiTNode *ptree,int (*visit)(int))
{
if(ptree)
{
if(visit(ptree->data))
if