资源简介
一个用C#写的简单的二叉树,可以创建、前序遍历、中序遍历、后续遍历。Windows 窗体应用程序。
代码片段和文件信息
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace BTree1
{
class BinaryTree
{
//成员变量
private Node _head; //头指针
private string cStr; //用于构造二叉树的字符串
private string preResult midResult posResult;//遍历结果
public Node Head //头指针
{
get { return _head; }
}
//构造方法
public BinaryTree(string constructStr)
{
cStr = constructStr;
_head = new Node(cStr[0]); //添加头结点
Add(_head 0); //给头结点添加孩子结点
preResult = ““;
midResult = ““;
posResult = ““;
}
private void Add(Node parent int index)
{
int leftIndex = 2 * index + 1; //计算左孩子索引
if (leftIndex < cStr.Length) //如果索引没超过字符串长度
{
if (cStr[leftIndex] != ‘#‘) //‘#‘表示空结点
{
//添加左孩子
parent.Left = new Node(cStr[leftIndex]);
//递归调用Add方法给左孩子添加孩子节点
Add(parent.Left leftIndex);
}
}
int rightIndex = 2 * index + 2;
if (rightIndex < cStr.Length)
{
if (cStr[rightIndex] != ‘#‘)
{
//添加右孩子
parent.Right = new Node(cStr[rightIndex]);
//递归调用Add方法给右孩子添加孩子节点
Add(parent.Right rightIndex);
}
}
}
public string PreOrder(Node node) //先序遍历
{
if (node != null)
{
preResult += node.ToString(); //打印字符
PreOrder(node.Left); //递归
PreOrder(node.Right); //递归
}
return preResult;
}
public string MidOrder(Node node) //中序遍历
{
if (node != null)
{
MidOrder(node.Left); //递归
midResult += node.ToString(); //打印字符
MidOrder(node.Right); //递归
}
return midResult;
}
public string AfterOrder(Node node) //后继遍历
{
if (node != null)
{
AfterOrder(node.Left); //递归
AfterOrder(node.Right); //递归
posResult += node.ToString(); //打印字符
}
return posResult;
}
}
}
属性 大小 日期 时间 名称
----------- --------- ---------- ----- ----
文件 11264 2011-04-21 13:14 BTree1\BTree1\bin\Debug\BTree1.exe
文件 34304 2011-04-21 13:14 BTree1\BTree1\bin\Debug\BTree1.pdb
文件 14328 2011-04-21 13:16 BTree1\BTree1\bin\Debug\BTree1.vshost.exe
文件 2792 2011-04-21 12:53 BTree1\BTree1\BinaryTree.cs
文件 3799 2011-04-20 23:27 BTree1\BTree1\BTree1.csproj
文件 1162 2011-04-21 12:59 BTree1\BTree1\Form1.cs
文件 6126 2011-04-21 12:59 BTree1\BTree1\Form1.Designer.cs
文件 5814 2011-04-21 12:59 BTree1\BTree1\Form1.resx
文件 856 2011-04-21 13:14 BTree1\BTree1\Node.cs
文件 893 2011-04-21 13:16 BTree1\BTree1\obj\Debug\BTree1.csproj.FileListAbsolute.txt
文件 847 2011-04-21 12:59 BTree1\BTree1\obj\Debug\BTree1.csproj.GenerateResource.Cache
文件 11264 2011-04-21 13:14 BTree1\BTree1\obj\Debug\BTree1.exe
文件 180 2011-04-21 12:59 BTree1\BTree1\obj\Debug\BTree1.Form1.resources
文件 34304 2011-04-21 13:14 BTree1\BTree1\obj\Debug\BTree1.pdb
文件 180 2011-04-20 23:30 BTree1\BTree1\obj\Debug\BTree1.Properties.Resources.resources
文件 487 2011-04-20 21:28 BTree1\BTree1\Program.cs
文件 1344 2011-04-20 21:28 BTree1\BTree1\Properties\AssemblyInfo.cs
文件 2862 2011-04-20 21:28 BTree1\BTree1\Properties\Resources.Designer.cs
文件 5612 2011-04-20 21:28 BTree1\BTree1\Properties\Resources.resx
文件 1091 2011-04-20 21:28 BTree1\BTree1\Properties\Settings.Designer.cs
文件 249 2011-04-20 21:28 BTree1\BTree1\Properties\Settings.settings
文件 908 2011-04-20 21:28 BTree1\BTree1.sln
..A..H. 17920 2011-04-21 18:59 BTree1\BTree1.suo
目录 0 2011-04-20 21:35 BTree1\BTree1\obj\Debug\Refactor
目录 0 2011-04-20 21:28 BTree1\BTree1\obj\Debug\TempPE
目录 0 2011-04-21 12:53 BTree1\BTree1\bin\Debug
目录 0 2011-04-21 13:14 BTree1\BTree1\obj\Debug
目录 0 2011-04-20 23:25 BTree1\BTree1\bin
目录 0 2011-04-20 21:28 BTree1\BTree1\obj
目录 0 2011-04-20 21:28 BTree1\BTree1\Properties
............此处省略5个文件信息
相关资源
- 智慧城市 智能家居 C# 源代码
- c#获取mobile手机的IMEI和IMSI
- C#实现简单QQ聊天程序
- 操作系统 模拟的 欢迎下载 C#版
- C#写的计算机性能监控程序
- 用C#实现邮件发送,有点类似于outlo
- MVC model层代码生成器 C#
- c#小型图书销售系统
- C# Socket Server Client 通讯应用 完整的服
- c# winform 自动登录 百度账户 源代码
- C#编写的16进制计算器
- C#TCP通信协议
- C# 数据表(Dataset)操作 合并 查询一
- C#语音识别系统speechsdk51,SpeechSDK51L
- 数据库备份还原工具1.0 C# 源码
-
[免费]xm
lDocument 节点遍历C# - EQ2008LEDc#开发实例
- DirectX.Capturec# winform 操作摄像头录像附
- c# 实现的最大最小距离方法对鸢尾花
- C#版保龄球记分代码
- C#自定义控件
- 基于c#的实验室设备管理系统621530
- C# 使用ListView控件实现图片浏览器(源
- C#简单窗体聊天程序
- C#指纹识别系统程序 报告
- c# 高校档案信息管理系统
- c#向word文件插入图片
- C#左侧导航菜单(动态生成)
- C#TCP 通信(TCP发送16进制)
- C# sql实现批量导入数据到数据库
评论
共有 条评论