网站大量收购闲置独家精品文档,联系QQ:2885784924

实验五二叉树的基本操作和应用实验报告.docx

实验五二叉树的基本操作和应用实验报告.docx

  1. 1、本文档共6页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
实验五二叉树的基本操作和应用实验报告.docx

重庆大学学生上机实验报告上机课程名称:数据结构上机实验名称:实验5 实验名称 二叉树的基本操作和应用 开课学院及实验室:经济与工商管理学院 2011年 7 月 1 日学 院经管学院年级、专业、班信息管理与信息系统姓 名苏浩辉学 导教师陈铿 成 绩教师评语教师签名: 【实验目的】给定如下二叉树,编程完成 该二叉树的先序,中序和后序遍历, 并输出其遍历序列。【实验内容】例程程序代码:using System;using System.Collections.Generic;using System.Linq;using System.Text;namespace 二叉树遍历{ class Node { private object _data; private Node _left; private Node _right; public object Data { get { return _data; } } public Node Left { get { return _left; } set { _left = value; } } public Node Right { get { return _right; } set { _right = value; } } public Node(object data) { _data = data; } public override string ToString() { return _data.ToString(); }}class BinaryTree{ private Node _head; private string cStr; public Node Head { get { return _head; } } public BinaryTree(string constructStr) { cStr = constructStr; _head = new Node(cStr[0]); Add(_head, 0); } 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(parent.Left, leftIndex); } } int rightIndex = 2 * index + 2; if (rightIndex cStr.Length) { if (cStr[rightIndex] != *) { parent.Right = new Node(cStr[rightIndex]); Add(parent.Right, rightIndex); } } } public void PreOrder(Node node) { if (node != null) { Console.Write(node.ToString()); PreOrder(node.Left); PreOrder(node.Right); } } public void MidOrder(Node node) { if (node != null) { MidOrder(node.Left); Console.Write(node.ToString()); MidOrder(node.Right); } } public void AfterOrder(Node node) { if (node != null) { AfterOrder(node.Left); AfterOrder(node.Right); Console.Write(node.ToString()); } } }class Program{ static void Main(string[] args) { BinaryTree bTree = new BinaryTree(ABCDEF*****G************H); Console.WriteLine(先序历遍为:\n); bTree.PreOrder(bTree.Head); //先序遍 Console.WriteLine(); Console.ReadLine(); Console.WriteLine(中序序历遍为:\n); bTree.MidOrder(bTree.Head); //中序遍 Console.WriteLine(); Console.ReadLine();

文档评论(0)

带头大哥 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档