数据结构与算法/树的应用

1、以二叉链表作存储结构,设计求二叉树高度的算法。

2、一棵 n 个结点的完全二叉树用向量作存储结构,用非递归算法实现对该

二叉树进行前序遍历。

3、以二叉链表作存储结构,编写非递归的前序、中序、后序遍历算法。

#include <iostream>

#include <string>

#define MAXSIZE 100

using namespace std;

 

typedef struct BiTNode

{

    char data;

    struct BiTNode *lchild,*rchild;

}BiTNode,*BiTree;

 

typedef int SqBiTree[MAXSIZE];

 

 

typedef struct StackNode

{

    char datac;

    struct StackNode *next;

}StackNode,*LinkStack;

 

typedef struct StackNode1

{

    BiTree data;

    struct StackNode1 *next;

}StackNode1,*LinkStack1;

 

void InitTree(BiTree &T)

{

    T=new BiTNode;

    T=NULL;

}

 

void InitStack(LinkStack &S)//

{

    S=new StackNode;

    S=NULL;

}

 

void InitStack1(LinkStack1 &S)//

{

    S=new StackNode1;

    S=NULL;

}

 

void Build(int *bt,int n)

{

    int x;

    cout<<"输入该完全二叉树:";

 

    for(int i=1;i<=n;i++)

    {

        cin>>x;

        bt[i]=x;

        //cout<<bt[i];

    }

}

 

void CreateTree(BiTree &T)

{

    char x;

    cin>>x;

    if('#'==x)

    T=NULL;

    else

    {

      T=new BiTNode;

      T->data=x;

      CreateTree(T->lchild);

      CreateTree(T->rchild);

    }

}

 

void Push(LinkStack &S,char e)

{

    LinkStack p=new StackNode;

    p->datac=e;

    p->next=S;

    S=p;

}

 

void Push1(LinkStack1 &S,BiTree e)

{

    LinkStack1 p=new StackNode1;

    p->data=e;

    p->next=S;

    S=p;

}

 

int Pop(LinkStack &S)

{

    LinkStack p=new StackNode;

    if(S==NULL)

    cout<<"栈为空";

    p=S;

    S=S->next;

    delete p;

}

 

void Pop1(LinkStack1 &S,BiTree &e)

{

    LinkStack1 p=new StackNode1;

    if(S==NULL)

    {

        cout<<"栈为空";

        return;

    }

 

    p=S;

    e=p->data;

    S=S->next;

    //return p->data;

    delete p;

}

 

int StackSize(LinkStack1 S)

{

    int i=0;

    while(S)

    {

        i++;

        S=S->next;

    }

    return i;

}

 

int GetTop(LinkStack &S)

{

    if(S!=NULL)

    return S->datac;

}

 

BiTree GetTop1(LinkStack1 &S)

{

    if(S!=NULL)

    return S->data;

}

 

int EmptyStack(LinkStack &S)

{

    if(S==NULL)

        return 1;

    else

        return 0;

}

 

int EmptyStack1(LinkStack1 &S)

{

    if(S==NULL)

        return 1;

    else

        return 0;

}

 

int Deepth(BiTree &T)

{

    int deep1,deep2;

    if(T==NULL)

        return 0;

    else

    {

      deep1=Deepth(T->lchild);

      deep2=Deepth(T->rchild);

      if(deep1>deep2)

      return (deep1+1);

      else

      return (deep2+1);

    }

}

 

void Order1(BiTree &T)

{

    LinkStack1 S;

    BiTNode *p=T;

    InitStack1(S);

    //p=new BiTNode;

    //p=T;

    while(p||!EmptyStack1(S))

    {

        while(p)

        {

            cout<<p->data<<" ";

            Push1(S,p);

            p=p->lchild;

        }

        if(!EmptyStack1(S))

        {

            Pop1(S,p);

            p=p->rchild;

        }

    }

}

 

void Order2(BiTree &T)

{

    LinkStack1 S;

    BiTNode *p=T;

    InitStack1(S);

    //p=new BiTNode;

    //p=T;

   //栈不空或者p不空时循环

    while(p||!EmptyStack1(S)){

        while(p)

            {

            //存入栈中

            Push1(S,p);

            //遍历左子树

            p=p->lchild;

            }

        if(!EmptyStack1(S)){

            //退栈,访问根节点

            Pop1(S,p);

            cout<<p->data<<" ";

            //Pop(S);

            //访问右子树

            p=p->rchild;

             }

    }//while

}

 

void Order3(BiTree &T)

{

    int flag[20];

    LinkStack1 S;

    BiTNode *p;

    InitStack1(S);

    p=new BiTNode;

    p=T;

    if(!p)

    {

        cout<<"空树!\n";

    }

 

    while(p||!EmptyStack1(S))

    {

        while(p)

       {

        Push1(S,p);

        flag[StackSize(S)]=0;

        p=p->lchild;

       }

       while(!EmptyStack1(S)){

           p=GetTop1(S);

           if(p->rchild&&flag[StackSize(S)]==0)

           {

            flag[StackSize(S)]=1;

            p=p->rchild;

            break;

           }

           else{

            p=GetTop1(S);

            cout<<p->data<<" ";

            Pop1(S,p);

            if(EmptyStack1(S)){

               return ;

            }

           }

       }

    }

}

 

void PreOrder(int *bt,int n)

{

     LinkStack S;

     InitStack(S);

     int i=1;

     while(i<=n||!EmptyStack(S))

     {

       while(i<=n)

       {

          cout<<bt[i]<<" ";

          Push(S,bt[i]);

          i=i*2;

       }

       if(!EmptyStack(S))

       {

          i=GetTop(S);

          Pop(S);

          i=2*i+1;

       }

     }

}

 

int main()

{

    BiTree T;

    LinkStack S;

    LinkStack1 S1;

    int i,t,n=0;

    int *bt;

    do{

    cout<<"\n1.二叉树高度   2.二叉树非递归遍历   3.向量二叉树遍历\n";

    cin>>t;

    if(t==1)

    {

        InitTree(T);

        InitStack(S);

        cout<<"建立一个树,空结点用#表示:";

        CreateTree(T);

        cout<<"二叉树高度为:";

        i=Deepth(T);

        cout<<i;

    }

    if(t==2)

    {

        InitTree(T);

        InitStack1(S1);

        cout<<"建立一个树,空结点用#表示:";

        CreateTree(T);

        cout<<"二叉树前序遍历:";

        Order1(T);

        cout<<endl;

        cout<<"二叉树中序遍历:";

        Order2(T);

        cout<<endl;

        cout<<"二叉树后序遍历:";

        Order3(T);

        cout<<endl;

    }

    if(t==3)

    {

        InitTree(T);

        cout<<"定义一个长度:";

        cin>>n;

        bt=new int[n+1];

        Build(bt,n);

        cout<<"输出原来的二叉树:";

        for(int i=1;i<=n;i++)

        cout<<bt[i]<<" ";

        cout<<endl;

        PreOrder(bt,n);

        cout<<endl;

    }

  }while(t!=3);

}

#include #include //#define error 0 //#define OVERFLOW -1 //#define ok 1 #define MAXSIZE 100 typedef char TElemType; typedef int Status; typedef struct BiTNode{ //的结点 TElemType data; struct BiTNode *lchild,*rchild; }BiTNode,*BiTree; typedef BiTree datatype; typedef struct { datatype data[MAXSIZE]; int top; }sqstack; typedef sqstack *STK; Status CreateBiTree(BiTree *T) { //建立二叉 char ch; ch=getchar(); if(ch=='#') (*T)=NULL; //#代表空 else { (*T)=(BiTree)malloc(sizeof(BiTNode)); (*T)->data=ch; CreateBiTree(&(*T)->lchild); //建立左子 CreateBiTree(&(*T)->rchild); //建立右子 } return 1; } STK initstack() //栈的初始化 { STK s; s=(STK)malloc(MAXSIZE*sizeof(sqstack)); s->top=0; return s; //返回指向栈地址的指针 } Status stackempty(STK s) //判断栈是否为空 { return(s->top==0); } Status push(STK s,datatype *e) //压栈函数 { if(s->top==MAXSIZE) //栈满,则返回错误 return 0; else { s->data[s->top]=*e; (s->top)++; return 1; } } Status pop(STK s,datatype *e) //出栈函数 { if(stackempty(s)) //判断栈是否为空 return 0; else { s->top--; *e=s->data[s->top]; //用e接受栈顶元素 return 1; } } Status inordertraverse(BiTree T) //中非递归历二叉 { STK s; s=initstack(); // BiTree T; BiTree p; p=T; while (p||!stackempty(s)) { if(p) { push(s,&p); p=p->lchild; } else { pop(s,&p); printf("%2c",p->data); p=p->rchild; }//else }//while return 1; }//inordertraverse void main() { BiTree T=NULL; printf("\n Creat a Binary Tree .\n"); //建立一棵二叉T* CreateBiTree( &T ); printf ("\nThe preorder is:\n"); inordertraverse(T); }
存储的线性表 时数 2 性质 验证 内容:1、设线性表存放在向量A[arrsize]的前elenum个分量中,且递增有。试设计一算法,将x插入到线性表的适当位置上,以保持线性表的有性。 2、用向量存储结构,试设计一个算法,仅用一个辅助结点,实现将线性表中的结点循环右移k位的运算。 3、用向量存储结构,试设计一个算法,仅用一个辅助结点,实现将线性表逆置的运算。 要求:了解线性表的逻辑结构特征,熟练掌握线性表的顺存储结构的描述方法,及在其上实现各种基本运算的方法。 单链表上的操作 时数 2 性质 验证 内容:1、已知带头结点的动态单链表L中的结点是按整数值递增排的,试算法将值为x的结点插入到表L中,使L仍然有。 2、设计一算法,逆置带头结点的动态链表L。要求利用原表的结点空间,并要求用尽可能少的时间完成。 3、假设有两个按元素值递增有的线性表A和B,均以单链表作存储结构试编算法将A表和B表归并成一个按元素值递减有的线性表C,并要求利用原表的空间存放C。 要求:熟练掌握线性表的单链式链接存储结构及在其上实现线性表的各种基本运算的方法。 循环链表和双链表 时数 2 性质 验证 内容:1、假设在长度大于1的单循环链表中,既无头结点也无头指针。s为指向某个结点的指针,试编算法删除结点*s的直接前驱结点。 2、已知由单链表表示的线性表中,含有三类字符的数据元素(如:字母、数字和其它字符),设计算法构造三个以循环链表示的线性表,使每一个表中只含同一类的字符,且利用原表中的结点空间作为这三个表的空间。(头结点可以另辟空间) 3、有一双链表,每个结点中除有prior、data和next域外,还有一访问频度域freq,在链表被启用前,其值均初始化为零。每当在链表上进行一次LOCATE(L,x)运算,元素值为x的结点中freq域的值增1,并使此链表中结点保持按freq递减的顺排列,以便使频繁访问的结点总是靠近表头。设计满足上述要求的LOCATE算法。 要求:熟练掌握线性表的循环链式和双链式链接存储结构及在其上实现线性表的各种基本运算的方法。 栈和队列 时数 2 性质 验证 内容:1、设单链表中存放着n个字符,设计算法,判断该字符串中是否有中心对称关系。例如:xyzzyx、xyzyx都算是中心对称的字符串。 2、设计算法判断一个算术表达式的圆括号是否配对。(提示:对表达式进行扫描,遇‘(’进栈,遇‘)’退掉栈顶的‘(’,表达式被扫描完毕,栈为空) 3、假设以带头结点的循环链表表示队列,并只设一个指针指向队尾,编相应的置队空、入队和出队算法。 要求:掌握栈和队列的数据结构的特点;熟练掌握在两种存储结构实现栈和队列的基本运算;学会利用栈和队列解决一些实际问题。 串运算的实现 时数 2 性质 验证 内容:1、若X和Y是用结点大小为1的单链表表示的串,设计算法找出X中第一个不在Y中出现的字符。 2、设计一算法,在顺串上实现串的比较运算strcmp(S,T)。 3、若S和T是用结点大小为1的单链表存储的两个串,设计算法将S中首次T匹配的子串逆置。 要求:熟练掌握串的顺和链接存储结构实现方法;熟练掌握在两种存储结构实现串的各种运算。 应用 时数 2 性质 验证 内容:1、以二叉链表作存储结构,设计求二叉高度的算法。 2、一棵n个结点的完全二叉树向量存储结构,用非递归算法实现对该二叉进行前历。 3、以二叉链表作存储结构,编非递归的前、中、后算法。 要求:熟悉二叉的各种存储结构的特点及适用范围;掌握建立二叉存储结构的方法;熟练掌握二叉的前、中、后历的递归及非递归算法;灵活运用递归的算法实现二叉的其它各种运算。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值