后序遍历还没有明白,继续学习^_^,过几天写个huffman编码的例子来玩玩,不多说了,看代码吧,注意:程序申请的空间并没有释放^_^

 /**//********************************************************************
/**//********************************************************************
 created:    2005/12/30
    created:    2005/12/30
 created:    30:12:2005   10:39
    created:    30:12:2005   10:39
 filename:     bintree.h
    filename:     bintree.h
 author:        Liu Qi
    author:        Liu Qi
 
    
 purpose:    二叉树的3种遍历方式(包括非递归实现),前序,后序和中序,先访问根节点就是
    purpose:    二叉树的3种遍历方式(包括非递归实现),前序,后序和中序,先访问根节点就是
 前序(部分书籍称为先根遍历,个人觉得该说法更好^_^),类似的,最后访问根节点就是后序
    前序(部分书籍称为先根遍历,个人觉得该说法更好^_^),类似的,最后访问根节点就是后序
 *********************************************************************/
*********************************************************************/


 #ifndef TREE_H
#ifndef TREE_H
 #define TREE_H
#define TREE_H


 #include <stdio.h>
#include <stdio.h>
 #include <malloc.h>
#include <malloc.h>
 #include <stack>
#include <stack>
 #include <queue>
#include <queue>
 #include <assert.h>
#include <assert.h>

 using namespace std;
using namespace std;



 typedef int ElemType;
typedef int ElemType;

 typedef struct treeT
typedef struct treeT


 {
{
 ElemType key;
    ElemType key;
 struct treeT* left;
    struct treeT* left;
 struct treeT* right;
    struct treeT* right;
 }treeT, *pTreeT;
}treeT, *pTreeT;





 /**//*===========================================================================
/**//*===========================================================================
 * Function name:    visit
* Function name:    visit
 * Parameter:        root:树根节点指针
* Parameter:        root:树根节点指针
 * Precondition:
* Precondition:        
 * Description:
* Description:        
 * Return value:
* Return value:        
 * Author:            Liu Qi, //-
* Author:            Liu Qi, //-
 ===========================================================================*/
===========================================================================*/
 static void visit(pTreeT root)
static void visit(pTreeT root)


 {
{
 if (NULL != root)
    if (NULL != root)

 
     {
{
 printf(" %d\n", root->key);
        printf(" %d\n", root->key);
 }
    }
 }
}




 /**//*===========================================================================
/**//*===========================================================================
 * Function name:  BT_MakeNode
* Function name:  BT_MakeNode    
 * Parameter:      target:元素值
* Parameter:      target:元素值    
 * Precondition:      None
* Precondition:      None    
 * Postcondition:  NULL != pTreeT
* Postcondition:  NULL != pTreeT 
 * Description:      构造一个tree节点,置左右指针为空,并且返回指向新节点的指针
* Description:      构造一个tree节点,置左右指针为空,并且返回指向新节点的指针    
 * Return value:      指向新节点的指针
* Return value:      指向新节点的指针    
 * Author:            Liu Qi,  [12/30/2005]
* Author:            Liu Qi,  [12/30/2005]
 ===========================================================================*/
===========================================================================*/
 static pTreeT BT_MakeNode(ElemType target)
static pTreeT BT_MakeNode(ElemType target)


 {
{
 pTreeT pNode = (pTreeT) malloc(sizeof(treeT));
    pTreeT pNode = (pTreeT) malloc(sizeof(treeT));

 assert( NULL != pNode );
    assert( NULL != pNode ); 

 pNode->key   = target;
    pNode->key   = target;
 pNode->left  = NULL;
    pNode->left  = NULL;
 pNode->right = NULL;
    pNode->right = NULL;
 
    
 return pNode;
    return pNode;
 }
}



 /**//*===========================================================================
/**//*===========================================================================
 * Function name:    BT_Insert
* Function name:    BT_Insert
 * Parameter:        target:要插入的元素值, pNode:指向某一个节点的指针
* Parameter:        target:要插入的元素值, pNode:指向某一个节点的指针
 * Precondition:         NULL != ppTree
* Precondition:         NULL != ppTree 
 * Description:        插入target到pNode的后面
* Description:        插入target到pNode的后面
 * Return value:        指向新节点的指针
* Return value:        指向新节点的指针
 * Author:            Liu Qi,  [12/29/2005]
* Author:            Liu Qi,  [12/29/2005]
 ===========================================================================*/
===========================================================================*/
 pTreeT BT_Insert(ElemType target, pTreeT* ppTree)
pTreeT BT_Insert(ElemType target, pTreeT* ppTree)


 {
{
 pTreeT Node;
    pTreeT Node;

 assert( NULL != ppTree );
    assert( NULL != ppTree ); 

 Node = *ppTree;
    Node = *ppTree;
 if (NULL == Node)
    if (NULL == Node)

 
     {
{
 return *ppTree = BT_MakeNode(target);
        return *ppTree = BT_MakeNode(target);
 }
    }

 if (Node->key == target)    //不允许出现相同的元素
    if (Node->key == target)    //不允许出现相同的元素

 
     {
{
 return NULL;
        return NULL;
 }
    }
 else if (Node->key > target)    //向左
    else if (Node->key > target)    //向左

 
     {
{
 return BT_Insert(target, &Node->left);
        return BT_Insert(target, &Node->left);
 }
    }
 else
    else

 
     {
{
 return BT_Insert(target, &Node->right);
        return BT_Insert(target, &Node->right);
 }
    }
 }
}





 /**//*===========================================================================
/**//*===========================================================================
 * Function name:    BT_PreOrder
* Function name:    BT_PreOrder
 * Parameter:        root:树根节点指针
* Parameter:        root:树根节点指针
 * Precondition:        None
* Precondition:        None
 * Description:        前序遍历
* Description:        前序遍历
 * Return value:        void
* Return value:        void
 * Author:            Liu Qi,  [12/29/2005]
* Author:            Liu Qi,  [12/29/2005]
 ===========================================================================*/
===========================================================================*/
 void BT_PreOrder(pTreeT root)
void BT_PreOrder(pTreeT root)


 {
{
 if (NULL != root)
    if (NULL != root)

 
     {
{
 visit(root);
        visit(root);
 BT_PreOrder(root->left);
        BT_PreOrder(root->left);
 BT_PreOrder(root->right);
        BT_PreOrder(root->right);
 }
    }    
 }
}



 /**//*===========================================================================
/**//*===========================================================================
 * Function name:    BT_PreOrderNoRec
* Function name:    BT_PreOrderNoRec
 * Parameter:        root:树根节点指针
* Parameter:        root:树根节点指针
 * Precondition:        Node
* Precondition:        Node
 * Description:        前序(先根)遍历非递归算法
* Description:        前序(先根)遍历非递归算法
 * Return value:        void
* Return value:        void
 * Author:            Liu Qi,  [1/1/2006]
* Author:            Liu Qi,  [1/1/2006]
 ===========================================================================*/
===========================================================================*/
 void BT_PreOrderNoRec(pTreeT root)
void BT_PreOrderNoRec(pTreeT root)


 {
{
 stack<treeT *> s;
    stack<treeT *> s;

 while ((NULL != root) || !s.empty())
    while ((NULL != root) || !s.empty())

 
     {
{
 if (NULL != root)
        if (NULL != root)

 
         {
{
 visit(root);
            visit(root);
 s.push(root);
            s.push(root);
 root = root->left;
            root = root->left;
 }
        }
 else
        else

 
         {
{
 root = s.top();
            root = s.top();
 s.pop();
            s.pop();
 root = root->right;
            root = root->right;
 }
        }
 }
    }
 }
}




 /**//*===========================================================================
/**//*===========================================================================
 * Function name:    BT_InOrder
* Function name:    BT_InOrder
 * Parameter:        root:树根节点指针
* Parameter:        root:树根节点指针
 * Precondition:        None
* Precondition:        None
 * Description:        中序遍历
* Description:        中序遍历
 * Return value:        void
* Return value:        void
 * Author:            Liu Qi,  [12/30/2005]
* Author:            Liu Qi,  [12/30/2005]
 ===========================================================================*/
===========================================================================*/
 void BT_InOrder(pTreeT root)
void BT_InOrder(pTreeT root)


 {
{
 if (NULL != root)
    if (NULL != root)

 
     {
{
 BT_InOrder(root->left);
        BT_InOrder(root->left);
 visit(root);
        visit(root);
 BT_InOrder(root->right);
        BT_InOrder(root->right);
 }
    }
 }
}



 /**//*===========================================================================
/**//*===========================================================================
 * Function name:    BT_InOrderNoRec
* Function name:    BT_InOrderNoRec
 * Parameter:        root:树根节点指针
* Parameter:        root:树根节点指针
 * Precondition:        None
* Precondition:        None
 * Description:        中序遍历,非递归算法
* Description:        中序遍历,非递归算法
 * Return value:        void
* Return value:        void
 * Author:            Liu Qi,  [1/1/2006]
* Author:            Liu Qi,  [1/1/2006]
 ===========================================================================*/
===========================================================================*/
 void BT_InOrderNoRec(pTreeT root)
void BT_InOrderNoRec(pTreeT root)


 {
{
 stack<treeT *> s;
    stack<treeT *> s;
 while ((NULL != root) || !s.empty())
    while ((NULL != root) || !s.empty())

 
     {
{
 if (NULL != root)
        if (NULL != root)

 
         {
{
 s.push(root);
            s.push(root);
 root = root->left;
            root = root->left;
 }
        }
 else
        else

 
         {
{
 root = s.top();
            root = s.top();
 visit(root);
            visit(root);
 s.pop();
            s.pop();
 root = root->right;
            root = root->right;
 }
        }
 }
    }
 }
}




 /**//*===========================================================================
/**//*===========================================================================
 * Function name:    BT_PostOrder
* Function name:    BT_PostOrder
 * Parameter:        root:树根节点指针
* Parameter:        root:树根节点指针
 * Precondition:        None
* Precondition:        None
 * Description:        后序遍历
* Description:        后序遍历
 * Return value:        void
* Return value:        void
 * Author:            Liu Qi,  [12/30/2005]
* Author:            Liu Qi,  [12/30/2005]
 ===========================================================================*/
===========================================================================*/
 void BT_PostOrder(pTreeT root)
void BT_PostOrder(pTreeT root)


 {
{
 if (NULL != root)
    if (NULL != root)

 
     {
{
 BT_PostOrder(root->left);
        BT_PostOrder(root->left);
 BT_PostOrder(root->right);
        BT_PostOrder(root->right);
 visit(root);
        visit(root);    
 }
    }
 }
}



 /**//*===========================================================================
/**//*===========================================================================
 * Function name:    BT_PostOrderNoRec
* Function name:    BT_PostOrderNoRec
 * Parameter:        root:树根节点指针
* Parameter:        root:树根节点指针
 * Precondition:        None
* Precondition:        None
 * Description:        后序遍历,非递归算法
* Description:        后序遍历,非递归算法
 * Return value:        void
* Return value:        void
 * Author:            Liu Qi, //  [1/1/2006]
* Author:            Liu Qi, //  [1/1/2006]
 ===========================================================================*/
===========================================================================*/
 void BT_PostOrderNoRec(pTreeT root)
void BT_PostOrderNoRec(pTreeT root)


 {
{
 //学习中,尚未明白
//学习中,尚未明白
 }
}



 /**//*===========================================================================
/**//*===========================================================================
 * Function name:    BT_LevelOrder
* Function name:    BT_LevelOrder
 * Parameter:        root:树根节点指针
* Parameter:        root:树根节点指针
 * Precondition:        NULL != root
* Precondition:        NULL != root
 * Description:        层序遍历
* Description:        层序遍历
 * Return value:        void
* Return value:        void
 * Author:            Liu Qi,  [1/1/2006]
* Author:            Liu Qi,  [1/1/2006]
 ===========================================================================*/
===========================================================================*/
 void BT_LevelOrder(pTreeT root)
void BT_LevelOrder(pTreeT root)


 {
{
 queue<treeT *> q;
    queue<treeT *> q;
 treeT *treePtr;
    treeT *treePtr;

 assert( NULL != root );
    assert( NULL != root ); 

 q.push(root);
    q.push(root);

 while (!q.empty())
    while (!q.empty())

 
     {
{
 treePtr = q.front();
        treePtr = q.front();
 q.pop();
        q.pop();
 visit(treePtr);
        visit(treePtr);

 if (NULL != treePtr->left)
        if (NULL != treePtr->left)

 
         {
{
 q.push(treePtr->left);
            q.push(treePtr->left);    
 }
        }
 if (NULL != treePtr->right)
        if (NULL != treePtr->right)

 
         {
{
 q.push(treePtr->right);
            q.push(treePtr->right);
 }
        }    
 
            
 }
    }
 }
}


 #endif
#endif

测试代码
 #include <stdio.h>
#include <stdio.h>
 #include <stdlib.h>
#include <stdlib.h>
 #include <time.h>
#include <time.h>
 #include "tree.h"
#include "tree.h"

 #define MAX_CNT 5
#define MAX_CNT 5
 #define BASE  100
#define BASE  100

 int main(int argc, char *argv[])
int main(int argc, char *argv[])


 {
{
 int i;
    int i;
 pTreeT root = NULL;
    pTreeT root = NULL;
 
    
 srand( (unsigned)time( NULL ) );
    srand( (unsigned)time( NULL ) ); 
 
    
 for (i=0; i<MAX_CNT; i++)
    for (i=0; i<MAX_CNT; i++)

 
     {
{
 BT_Insert(rand() % BASE, &root);
        BT_Insert(rand() % BASE, &root);
 }
    }

 //前序
    //前序
 printf("PreOrder:\n");
    printf("PreOrder:\n");
 BT_PreOrder(root);
    BT_PreOrder(root);
 printf("\n");
    printf("\n");

 printf("PreOrder no recursion:\n");
    printf("PreOrder no recursion:\n");
 BT_PreOrderNoRec(root);
    BT_PreOrderNoRec(root);
 printf("\n");
    printf("\n");
 
    
 //中序
    //中序
 printf("InOrder:\n");
    printf("InOrder:\n");
 BT_InOrder(root);
    BT_InOrder(root);
 printf("\n");
    printf("\n");

 printf("InOrder no recursion:\n");
    printf("InOrder no recursion:\n");
 BT_InOrderNoRec(root);
    BT_InOrderNoRec(root);
 printf("\n");
    printf("\n");

 //后序
    //后序
 printf("PostOrder:\n");
    printf("PostOrder:\n");
 BT_PostOrder(root);
    BT_PostOrder(root);
 printf("\n");
    printf("\n");

 //层序
    //层序
 printf("LevelOrder:\n");
    printf("LevelOrder:\n");
 BT_LevelOrder(root);
    BT_LevelOrder(root);
 printf("\n");
    printf("\n");
 
    
 return 0;
    return 0;
 }
}如果有兴趣不妨运行一下,看看效果^_^
另外请教怎样让二叉树漂亮的输出,即按照树的形状输出