| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 867 人关注过本帖, 1 人收藏
标题:数据结构试验——二叉树
只看楼主 加入收藏
晓婷长月
Rank: 1
等 级:新手上路
帖 子:61
专家分:0
注 册:2013-6-4
收藏(1)
 问题点数:0 回复次数:1 
数据结构试验——二叉树
数据结构试验——二叉树
程序代码:
#include<iostream>
using namespace std;
#define Maxlen 100
typedef char Elemtype;
typedef struct{
    Elemtype data[Maxlen];
    int length;
}Tree;
//链式定义
typedef struct node
{
    Elemtype data;
    struct node *lchild;
    struct node *rchild;
}Btree;
void InitTree(Tree *t,int m)
{
    t->length=m;
    for(int i=0;i<t->length;i++)
        t->data[i]='#';
    cout<<"二叉树初始化成功!\n";
}
void add(Tree *t,Elemtype a,int i)
{
    t->data[i]=a;
}
void display(Tree *t)
{
   cout<<"二叉树中的元素为:";
   for(int j=0;j<t->length;j++)
      cout<<t->data[j]<<' ';
   cout<<endl;
}
//转化函数
void change(Tree *t)
{
    Btree *stack[Maxlen];
    int top=0,to=1;
    stack[top]=(Btree*)malloc(sizeof(Btree));
    stack[top]->data=t->data[to-1];
    top++;
    while(top>0)
    {
       top--;
       if((t->data[2*to-1]!='#') && (t->data[2*to]!='#'))
       {
         stack[top]->lchild=(Btree*)malloc(sizeof(Btree));
         stack[top]->lchild->data=t->data[2*to-1];
         stack[top]->rchild=(Btree*)malloc(sizeof(Btree));
         stack[top]->rchild->data=t->data[2*to];
         top++;
         to++;
       }
     
    }
    cout<<"转化成功!\n";

}
void main()
{
    int n;
    Elemtype a;
    Tree tr;
    char b;
    cout<<"请输入需要输入的树的结点的个数:";
    cin>>n;
    InitTree(&tr,n);
    display(&tr);
    for(int i=0;i<n;i++)
    {
      cout<<"请输入二叉树的第"<<i+1<<"个结点,若为空结点,请输入#:";
      cin>>a;
      add(&tr,a,i);
    }
    cout<<"是否需要显示二叉树的元素y/n:";
    cin>>b;
    if (b=='y'|| b=='Y')
        display(&tr);
    change(&tr);
}


搜索更多相关主题的帖子: 二叉树 
2013-06-16 02:56
晓婷长月
Rank: 1
等 级:新手上路
帖 子:61
专家分:0
注 册:2013-6-4
收藏
得分:0 
全部资源文件
二叉树.rar (1.19 KB)
2013-06-16 02:57
快速回复:数据结构试验——二叉树
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.025079 second(s), 11 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved