二叉树
using System; using System.Collections.Generic; using System.Threading.Tasks; namespace MyTree { class Tree<T> where T:IComparable<T> //该接口用于处理泛型的大小比较 { private T Data; //数据 private int count; //数据的次数 private Tree<T> LTree;//左子树 private Tree<T> RTree;//右子树 public Tree(T value) { Data = value; count = 1; LTree = null; RTree = null; } public void Insert(T newTree) { T currentNodeValue = this.Data; if(currentNodeValue.CompareTo(newTree)>0) { if(this.LTree==null) { this.LTree = new Tree<T>(newTree); } else { this.LTree.Insert(newTree); } } else if (currentNodeValue.CompareTo(newTree)<0) { if(this.RTree==null) { this.RTree = new Tree<T>(newTree); } else { this.RTree.Insert(newTree); } } else { this.count++; } } /// <summary> /// 中序遍历 /// </summary> public void midOrder() { if(this.LTree!=null) { this.LTree.midOrder(); } Console.WriteLine(this.Data+","+this.count); if(this.RTree!=null) { this.RTree.midOrder(); } } /// <summary> /// 先序遍历 /// </summary> public void firstOrder() { Console.WriteLine(this.Data + "," + this.count); if (this.LTree != null) { this.LTree.firstOrder(); } if (this.RTree != null) { this.RTree.firstOrder(); } } /// <summary> /// 后序遍历 /// </summary> public void lastOrder() { Console.WriteLine(this.Data + "," + this.count); if (this.LTree != null) { this.LTree.lastOrder(); } if (this.RTree != null) { this.RTree.lastOrder(); } } } }
using System; namespace MyTree { class Program { static void Main(string[] args) { Tree<int> tree = new Tree<int>(10); tree.Insert(2); tree.Insert(4); tree.Insert(9); tree.Insert(15); Console.WriteLine("先序遍历"); tree.firstOrder(); Console.WriteLine(); Console.WriteLine("后序遍历"); tree.lastOrder(); Console.WriteLine(); Console.WriteLine("中序遍历"); tree.midOrder(); Console.ReadKey(); } } }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!