4.3&4.4二叉树的链式存储和遍历
 // DataStructTest.cpp : Defines the entry point for the console application.
// DataStructTest.cpp : Defines the entry point for the console application. //
//
 #include "stdafx.h"
#include "stdafx.h" #include <iostream.h>
#include <iostream.h> #include <malloc.h>
#include <malloc.h>
 typedef struct btnode * bitreptr;
typedef struct btnode * bitreptr;
 struct btnode
struct btnode {
{ char data;                    //数据
    char data;                    //数据 bitreptr lchild;            //左节点指针
    bitreptr lchild;            //左节点指针 bitreptr rchild;            //右节点指针
    bitreptr rchild;            //右节点指针 };
};
 //建立一个树,与书中P84中的是一样的,函数返回一个树的头指针
//建立一个树,与书中P84中的是一样的,函数返回一个树的头指针 bitreptr CreateTree()
bitreptr CreateTree()             {
{ bitreptr A,B,C,D,E,F;
    bitreptr A,B,C,D,E,F; bitreptr nodes[6];
    bitreptr nodes[6]; for(int i=0;i<6;i++)
    for(int i=0;i<6;i++) {
    { nodes[i]=(bitreptr)malloc(sizeof(btnode));
        nodes[i]=(bitreptr)malloc(sizeof(btnode)); nodes[i]->lchild=NULL;
        nodes[i]->lchild=NULL; nodes[i]->rchild=NULL;
        nodes[i]->rchild=NULL; }
    } A=nodes[0];
    A=nodes[0]; B=nodes[1];
    B=nodes[1]; C=nodes[2];
    C=nodes[2]; D=nodes[3];
    D=nodes[3]; E=nodes[4];
    E=nodes[4]; F=nodes[5];
    F=nodes[5];
 A->data='A';
    A->data='A'; A->lchild=B;
    A->lchild=B; A->rchild=E;
    A->rchild=E;
 B->data='B';
    B->data='B'; B->lchild=C;
    B->lchild=C; B->rchild=D;
    B->rchild=D;
 C->data='C';
    C->data='C';
 D->data='D';
    D->data='D';
 E->data='E';
    E->data='E'; E->rchild=F;
    E->rchild=F;
 F->data='F';
    F->data='F';
 return A;
    return A; }
}
 void visit(const bitreptr node)
void visit(const bitreptr node) {
{ cout<<node->data<<endl;;
    cout<<node->data<<endl;; }
}
 //先根遍历
//先根遍历 void preorder(const bitreptr root)
void preorder(const bitreptr root) {
{ bitreptr node=root;
    bitreptr node=root; if (node!=NULL)
    if (node!=NULL) {
    { visit(node);
        visit(node); preorder(node->lchild);
        preorder(node->lchild); preorder(node->rchild);
        preorder(node->rchild); }
    } }
} //中根遍历
//中根遍历 void inorder(const bitreptr root)
void inorder(const bitreptr root) {
{ bitreptr node=root;
    bitreptr node=root; if (node!=NULL)
    if (node!=NULL) {
    { inorder(node->lchild);
        inorder(node->lchild); visit(node);
        visit(node); inorder(node->rchild);
        inorder(node->rchild); }
    } }
} //后根遍历
//后根遍历 void postorder(const bitreptr root)
void postorder(const bitreptr root) {
{ bitreptr node=root;
    bitreptr node=root; if (node!=NULL)
    if (node!=NULL) {
    { postorder(node->lchild);
        postorder(node->lchild); postorder(node->rchild);
        postorder(node->rchild); visit(node);
        visit(node); }
    } }
} //计算叶子的数目
//计算叶子的数目 void countleaf(const bitreptr t,int & count)
void countleaf(const bitreptr t,int & count) {
{ if (t!=NULL)
    if (t!=NULL) {
    { if (t->lchild==NULL &&t->rchild==NULL)
        if (t->lchild==NULL &&t->rchild==NULL) count++;
            count++; countleaf(t->lchild,count);
        countleaf(t->lchild,count); countleaf(t->rchild,count);
        countleaf(t->rchild,count); }
    } }
}
 int main(int argc, char* argv[])
int main(int argc, char* argv[]) {
{ bitreptr root;
    bitreptr root; //建立树
    //建立树 root=CreateTree();
    root=CreateTree(); //
    // cout<<"先根遍历"<<endl;
    cout<<"先根遍历"<<endl; preorder(root);
    preorder(root); //
    // cout<<"中根遍历"<<endl;
    cout<<"中根遍历"<<endl; inorder(root);
    inorder(root); //
    // cout<<"后根遍历"<<endl;
    cout<<"后根遍历"<<endl; postorder(root);
    postorder(root); //
    // cout<<endl;
    cout<<endl; int count=0;
    int count=0; countleaf(root,count);
    countleaf(root,count); cout<<"页子的数量为:"<<count<<endl;
    cout<<"页子的数量为:"<<count<<endl; return 0;
    return 0; }
}
    一点说明:为什么在标题中要嵌入英文?原因是为了能够让国外的网友能查询到这篇文章。平常在Google上查资料的时候,经常参考国外网友的博客,帮助我解决了很多问题,所以我也想让他们能够参考我写的内容。当然文中我不可能全部译为英文,所以我尽量把代码粘全,靠代码说话吧。
 
                    
                     
                    
                 
                    
                


 
     
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号