数据结构与算法(c#实现)

数据结构与算法(c#实现)

ID:857277

大小:229.03 KB

页数:39页

时间:2017-09-20

数据结构与算法(c#实现)_第1页
数据结构与算法(c#实现)_第2页
数据结构与算法(c#实现)_第3页
数据结构与算法(c#实现)_第4页
数据结构与算法(c#实现)_第5页
资源描述:

《数据结构与算法(c#实现)》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库

1、数据结构与算法(C#实现)系列-----前言Heavenkiller(原创)搞计算机的人都应该很清楚,语言只是一种工具,算法才是灵魂。现在的开发语言有很多,如C++,VB,Perl,java,c#,还有如脚本语言js,vbs等,在如此多的选择面前,很多人不知道该选择哪一种好。其实不管哪一种语言,既然他存在,就一定有他的价值,有它的特定用途,而这往往是其它语言所无法比拟的。譬如C++就适合于系统底层的编程,而java一般就用于对稳定性,兼容性要求较高的场合,正所谓各有所长。像我一般用C++编写网络基层和与操作系统相关的程序,用C#写ASP.NET等程

2、序,必要的时候再辅以Rose,RationalXDE等建模工具。但无论选择哪一种语言,算法才是根本,掌握了算法,就掌握了所有语言的根本,以不变应万变。微软的C#是一种全新的语言,利用它能快捷、高效地布署程序。现在关于C#的资料也已经有很多了,各个方面的资料都能找得到,但用C#做数据结构的似乎还没有什么,在CSDN上我只找到了三四篇,而且仅仅是讲了一下链表之类简单的数据结构。于是我利用空闲的时间用C#写了一些数据结构与算法的实现,希望对大家学习数据结构能够有所帮助。另外,由于时间仓促,难免出现一些纰漏,希望大家不吝赐教给予指正,我的email是hea

3、venkiller2002@yahoo.com.cn.欢迎大家和我一起交流学习。本系列包括树,N叉树,广义树,二叉树,BST二叉查找树,AVL平衡树,堆,二叉堆,以及图。还有一些如哈希表,散列,左翼树,二项树,Haffman编码树等因时间关系,暂时未能奉上,以后有时间再补上吧。首先给大家展示一幅用RationalXDEfor.NET生成的类模型图,让大家对所有的类有一个大概的了解。数据结构与算法(C#实现)系列---演示篇(一)Heavenkiller(原创)这一篇主要是针对以后各篇的数据类型进行一个实质性的演示。因此希望大家具体看了各种数据结构的

4、分析之后再看这篇。主要包括如下几个方面的演示:1.堆栈。演示了一个利用堆栈作的RPN计算器2.排序表。演示了一个利用排序表做的多项式表达式的加法运算3.广义树。演示了深度遍历和广度遍历4.N叉树。演示了N叉树的生成插入删除等基本操作5.表达式树。演示了一个用二叉树和堆栈做的可以将一个后缀表达式翻译为日常中熟悉的中缀表达式的例子6.AVL树。演示了基本操作usingSystem;usingSystem.Collections;namespaceDataStructure{///

///Class1的摘要说明。///

5、classShow{///

///应用程序的主入口点。///[STAThread]staticvoidMain(string[]args){////TODO:在此处添加代码以启动应用程序//while(true){Console.WriteLine("pleasechooseatheNo.ofaitemyouwanttoperform:");Console.WriteLine("1.Stack-----RPNCalCulator");Console.WriteLine("2.SortedList-----thea

6、dditionofpolynomialrealizedbysortedlist");Console.WriteLine("3.GeneralTree----depthtravesalandbreathtraval");Console.WriteLine("4.NaryTree");Console.WriteLine("5.ExpressionTree");Console.WriteLine("6.AVLTree");Console.WriteLine("7.BinaryHeap");Console.WriteLine("exit--Exitthis

7、programme");//Test();switch(Console.ReadLine()){case"1"://ShowStackShowStack_RPNCalCulator();break;case"2"://SortedListShowSortedList_Polynomial();break;case"3":ShowGeneralTree_travel();break;case"4":ShowNaryTree();//演示一个三叉树的Attach和Detachbreak;case"5":ShowExpressionTree();brea

8、k;case"6":ShowAVLTree();break;case"7":ShowBinaryHeap();break;

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。