动态网站制作指南 [  QQ表情  ]
[ 投票调查 ]
[ 企业邮箱 ]
[ 网站空间 ]
网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
ASP源码 | .Net源码 | PHP源码 | JSP源码 | JAVA源码 | CGI源码 | VB源码 | C++源码 | Delphi源码 | PB源码 | VF源码 | 汇编 | 服务器
电脑书籍下载:程序设计书籍 | 数据库教程书籍 | 平面与多媒体书籍 | 网络通讯书籍 | 系统管理书籍 | 网络安全书籍 | 认证考试书籍
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > C/C++教程
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
文章搜索服务
邮件订阅
输入你的邮件地址,
你将不会错过任何关于:
[ C/C++教程 ]的信息



本月文章推荐
.VC++实现混合静态分裂视窗的方法.
.文件和设备编程.
.控制台窗口界面的编程控制(二).
.C语言高效编程的的四大绝招.
.玩转BCB的IDE,体验ToolsAPI.
.VC中借助DirectDraw实现水波的模.
.C例题讲解.
.C++ SDK+Symbian开发入门之运行.
.高手解答:关于RICHEDIT的两个问.
.C/C++ 跨平台I/O操作技巧.
.取得系统中网卡MAC地址的三种方法.
.C++中函数指针数组的使用.
.关闭DOS窗口.
.C++ Builder 设计工具.
.C++箴言:防止异常离开析构函数.
.Visual FoxPro 9 集成开发环境新.
.多变的立方体.
.C语言初学者的十八颗“地雷”.
.C++中处理XML文件.
.第 1 章 贪婪算法.

树的生成与遍历

发表日期:2008-3-8 |


  上次,应聘兼职时,他们给了我一些题目,其中的一道是,给我们一些数据,让我们生成树,并进行先,中,后序遍历!! 有问题的请E-mail:cangzhu@163.com 我的这样做的 : //建立树的方法是,取数组的中间的数为树根,左边的为左子树,右边的为右子树 #include "iostream.h"
#include "stdio.h"
#include "stdlib.h"
#include "string.h"
#define N 10 //节点类
class BNode
{
public:
 int data;
 BNode *lchild;
 BNode *rchild;  BNode()
  
}; //二叉树类
class BTree
{
private:
 BNode *root;
public:
 //构造函数
 BTree();
 //析构函数
 ~BTree();  //树的销毁
 void Destroy(BNode *node);
 
 //生成树
 bool CreateTree(BNode *node,int data[],int len);
 bool CreateTree(int data[],int len);  //遍历
 //先序
 void FirstSearch(BNode *node);
 void FirstSearch();
 
 //中序
 void MidSearch(BNode *node);
 void MidSearch();
 
 //后序
 void LastSearch(BNode *node);
 void LastSearch();
}; //构造函数
BTree::BTree()

 root=new BNode();
} //默认的析构函数
BTree::~BTree()
//树的销毁
void BTree::Destroy(BNode *node)
{
 if(!node)
  return;  delete node; 
 FirstSearch(node->lchild);
 FirstSearch(node->rchild);
} //递归的生成树
bool BTree::CreateTree(BNode *node,int data[N],int len)
{
 int i;  
 BNode *left=new BNode();
 BNode *right=new BNode();  //分割后,只剩一个数据
 if(len==1)
 {
  node->data=data[0];
  return true;
 }
 //分割后,只剩两个数据
 if(len==2)
 {
  node->data=data[1];   left=new BNode();
  left->data=data[0];   node->lchild=left;
  node->rchild=NULL;
  return true;
 }  //大于等于三个数据
 int mid=(int)(len/2);
 node->data=data[mid];
 node->lchild=left;
 node->rchild=right;  //左边的数据,右边的数据
 int left_data[N];
 int right_data[N];  //左子树的递归
 for(i=0;i<mid;i++)
 
 CreateTree(left,left_data,mid);  //右子树的递归
 for(i=0;i<len-mid-1;i++)
 
 CreateTree(right,right_data,len-mid-1);  return true;
} //生成树的函数
bool BTree::CreateTree(int data[N],int len)
{
 return CreateTree(root,data,len);
} //先序遍历
void BTree::FirstSearch(BNode *node)
{
 if(!node)
  return;  printf("%d ",node->data); 
 FirstSearch(node->lchild);
 FirstSearch(node->rchild);
}
void BTree::FirstSearch()
//中序遍历
void BTree::MidSearch(BNode *node)
{
 if(!node)
  return;   MidSearch(node->lchild);
 printf("%d ",node->data);
 MidSearch(node->rchild);
} void BTree::MidSearch()
//后序遍历
void BTree::LastSearch(BNode *node)
{
 if(!node)
  return;  LastSearch(node->lchild);
 LastSearch(node->rchild);
 printf("%d ",node->data);
} void BTree::LastSearch()
//测试函数
void main()
{
 BTree *T=new BTree();
 int data[N];
 for(int i=0;i<N;i++)
  data[i]=i;
 T->CreateTree(data,N); 
 T->FirstSearch();
 cout<<endl;
 T->MidSearch();
 cout<<endl;
 T->LastSearch();
}

上一篇:数据结构学习C++——二叉树 人气:420
下一篇:双人黑白棋子游戏 人气:246
浏览全部C/C++的内容 Dreamweaver插件下载 常用网页广告代码全集
  最新网站源码 最新软件下载
2008-7-24 Sablog-X v2.0 预览版
2008-7-24 帝国备份王EmpireBak 2008 正式版
2008-7-24 网趣网上购物系统时尚版 v8.2
2008-7-24 纵横B2B电子商务系统XYECS!B2B v
2008-7-24 e路小说小偷 v1.2.0723
2008-7-24 凌风美女图片站程序 v2.2
2008-7-24 TOM15电影收索程序
2008-7-24 清风信息自动采集生成系统 v1.0
2008-7-24 QQ邮箱编辑器 v1.0 (小小菜刀ASP
2008-7-19 UltraEdit 简体中文增强版 14.10
2008-7-19 CentOS 5.2 i386 LiveCD
2008-7-19 Snapture多功能相机 v1.4
2008-7-19 iAcces中文输入法 v1.0Build016
2008-7-19 Cookbook烹饪秘籍 v2.5
2008-7-19 苹果专用DVD转换工具 v1.1.59汉化
2008-7-19 Modem修复软件ZiPhone修改版04.0
2008-7-19 AgileMessenger即时通讯工具美化
2008-7-19 Sketches画图软件 v0.7b6破解版


  发表评论
姓 名: 验证码:
内 容:
[ 汉字翻译拼音 ] [ 广告代码 ] [ 符号对照表 ] [ 进制转换 ] [ 经典小工具 ] [ 个税计算 ] [ 汉字简繁转换 ] [ 普通单位换算 ] [ 公制单位换算 ]
[ 生辰老黄历 ] [ 国内电话区号 ] [ 国家代码与域名缩写 ] [ 文字加密解密 ] [ 健康查询 ] [ 万年历 ] [ 手机号码查询 ] [ ip搜索 ] [ Google PR查询 ]
业务联系 | 广告刊登 | 频道合作 | 投稿荐稿 | 联系方式 | 加入收藏 | RSS订阅
Copyright © 2000-2008 www.knowsky.com All rights reserved | 网络实名:动态网站制作指南 | 沪ICP备05001343号
ホームページ制作 不動産検索システム 求人情報
防水工事·改修工事 フットサル大会 探偵