硬件学院 | 网络学院 | 游戏秘籍 | 求职技巧 | 企业管理 | 软件资讯 | IT导购 | 软件下载 | 源码下载
软件学院 | 安全资讯 | 图形图象 | 网络营销 | 电子商务 | 硬件资讯 | IT生活 | 教程下载 | 电影娱乐
网站首页    个人求职    单位招聘    高校联盟    猎头服务    培训服务    资讯中心    IT论坛
让每一个热爱IT的人都找到一份满意的工作!
文章搜索:
 您的位置首页->-> 软件学院-> .NET技术-> 数据结构与算法(C#实现)系列---演示篇(三)
数据结构与算法(C#实现)系列---演示篇(三)
作者:中国资讯网 来源:zixuen.com 加入时间:2005-5-12 www.cnitrc.com
数据结构与算法(C#实现)系列---树(二)

Heavenkiller(原创)



public class InOrder:IPrePostVisitor

{

private IVisitor visitor;

public InOrder(IVisitor _vis){visitor=_vis;}

#region IPrePostVisitor 成员



public void PreVisit(object _obj)

{

// TODO: 添加 InOrder.PreVisit 实现

}



public void Visit(object _obj)

{

// TODO: 添加 InOrder.Visit 实现

this.visitor.Visit(_obj);

}



public void PostVisit(object _obj)

{

// TODO: 添加 InOrder.PostVisitor 实现

}



#endregion



}

public class PostOrder:IPrePostVisitor

{

private IVisitor visitor;

public PostOrder(IVisitor _vis){visitor=_vis;}

#region IPrePostVisitor 成员



public void PreVisit(object _obj)

{

// TODO: 添加 PostOrder.PreVisit 实现

}



public void Visit(object _obj)

{

// TODO: 添加 PostOrder.Visit 实现

}



public void PostVisit(object _obj)

{

// TODO: 添加 PostOrder.PostVisitor 实现

this.visitor.Visit(_obj);

}



#endregion



}

protected class EnumVisitor:IVisitor

{

Queue thisQueue;

public EnumVisitor(Queue _que)

{

this.thisQueue=_que;

}

#region IVisitor 成员



public void Visit(object _obj)

{

// TODO: 添加 EnumVisitor.Visit 实现

this.thisQueue.Enqueue(_obj);

}



#endregion

}









#region IEnumerable 成员



public IEnumerator GetEnumerator()

{

// TODO: 添加 Tree.GetEnumerator 实现

EnumVisitor vis=new EnumVisitor(this.keyqueue);

switch (this.traversaltype)

{

case TraversalType.Breadth:

BreadthFirstTraversal(vis);

break;

case TraversalType.PreDepth:

PreOrder preVis=new PreOrder(vis);

DepthFirstTraversal(preVis);

break;

case TraversalType.InDepth:

InOrder inVis=new InOrder(vis);

DepthFirstTraversal(inVis);

break;

case TraversalType.PostDepth:

PostOrder postVis=new PostOrder(vis);

DepthFirstTraversal(postVis);

break;



default:

Console.WriteLine("WARNING:please set a travel type first!--void SetTraversalType(TraversalType _type) ");

//throw new Exception("WARNING:please set a travel type first!");//if not set a type, a exception will happen

break;

}

return this.keyqueue.GetEnumerator();

}



#endregion
  相关文章:
.NET技术
ASP技术
PHP技术
JSP技术
.NET技术
服务器技术
数据库技术
其它类
工具软件
办公软件
本类阅读TOP10
 
关于我们   |   服务声明   |   使用帮助   |   广告合作   |   网站地图   |   友情链接   |   加盟合作   |   联系我们
Copyright © 2006 cnitrc.com Inc. All Rights Reserved. 浙ICP备05074295号
中国IT人才网 版权所有 网络实名:中国IT人才
未经书面授权严禁转载和复制本站的任何招聘信息和文章