数据结构课程设计-树形目录结构.docx

数据结构课程设计-树形目录结构.docx

ID:62250884

大小:71.30 KB

页数:21页

时间:2021-04-22

数据结构课程设计-树形目录结构.docx_第1页
数据结构课程设计-树形目录结构.docx_第2页
数据结构课程设计-树形目录结构.docx_第3页
数据结构课程设计-树形目录结构.docx_第4页
数据结构课程设计-树形目录结构.docx_第5页
资源描述:

《数据结构课程设计-树形目录结构.docx》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、树的遍历,文件目录结构的显示数据结构课程设计实验树的遍历,文件目录结构的显示实验报告一、简介树型结构是一类十分重要的非线性结构,它可以很好地描述客观世界中广泛存在的具有分支关系或层次特性的对象,如操作系统的文件构成、人工智能搜索算法的模型表示以及数据库系统的信息组织形式等。文件的目录结构是树型结构在计算机操作系统的典型应用。通过树型结构可以直观且清晰的表明操作系统中的文件组织结构。用户可通过树型结构显示的文件目录列表找到自己想访问的内容。本实验的要求在给出Unix下目录和文件信息的前提下,编程实现将其排列成一棵具有一定缩进的树。具体要求如下:输入要求输入数据

2、包含几个测试案例。每一个案例由几行组成,每以行都代表了目录树的层次结构。第一行代表目录的根节点。若是目录节点,那么它的孩子节点将在第二行中被输出,同时用一对圆括号“()”界定。同样,如果这些孩子节点中某一个也是目录的话,那么这个目录所包含的内容将在随后的一行中列出,由一对圆括号将首尾界定。目录的输入格式为:*namssize,文件的输入格式为:namesize,其中*代表当前节点是目录,name代表文件或目录的名称,由一串长度不大于10的字符组成,并且name字符串中不能含有‘(’,‘)’,‘[’,‘]’和‘*’。size是该文件/目录的大小,为一个大于0的

3、整数。每一个案例中最多只能包含10层,每一层最多有10个文件/目录。输出要求对每一个测试案例,输出时要求:第d层的文件/目录名前面需要插入8*d个空格,兄弟节点之间要在同一列上。不要使用Tab(制表符)来统一输出的缩进。每一个目录的大小(size)是它所包含的所有子目录和文件大小以及它自身大小的总和。有输入/输出样例如下:输入样例:*/usr1(*mark1*alex1)(hw.c3*course1)(hw.c5)19树的遍历,文件目录结构的显示(aa.txt12)*/usr1()输出样例:

4、_*/usr[24]

5、_*mark[17]

6、

7、_hw.c[3]

8、

9、

10、_*course[13]

11、_aa.txt[12]

12、_*alex[6]

13、_hw.c[5]

14、_*usr[1]因此,实验任务如下:(1)读入给定的Unix目录和文件信息。(2)建立树型链表以表示目录和文件结构,同时重新计算目录大小(3)以树型结构输出文件信息。二、设计说明2.1、数据结构实现目录结构是一种典型的树形结构,可以选择孩子兄弟双亲链表来储存树的结构。孩子兄弟双亲链表是一种典型的树的存储结构。在该表示方法中,链表中节点的三个指针域分别指向该节点的父亲、第一个孩子节点和下一个兄弟节点,分别命名为Parent域,FirstChild域和NextSibling域

15、。在孩子兄弟双亲链表表示法中,节点形式统一,节点间的联系比较简洁。同时,在这种存储结构上容易实现树数据结构的大多数运算。因此,孩子兄弟双亲链表表示是树的一种实用的储存结构。其节点形式如下:*FirstChilddata*NextSibling*Parent本题中采用面向对象的方式实现树型结构。构建Tree类,将所有的目录作为Tree类的对象。Tree类定义如下:classTree{stringName;//树的根节点名称intSize;//树的大小,用于统计树本身及其子数大小的总和Tree*FirstChild;//指向他的第一个孩子节点Tree*NextS

16、ibling;//指向下一个兄弟节点Tree*Parent;//指向父节点19树的遍历,文件目录结构的显示public:Tree(stringName=””,intSize=0);//构造函数voidparse();//根据输入数据建立树型结构voidreSize();//重新统计树节点的大小voidoutPut();//输出函数~Tree();//析构函数};2.2、主要函数的实现在Tree类中共定义了5个函数,即构造树(Tree()构造函数),销毁树(~Tree()析构函数),目录大小计算(reSize()函数),建立树型链表结构(parse()函数)和

17、树型结构输出(outPut()函数)。下面分别说明如下:2.2.1构造函数构造函数的作用是建立一个只有一个节点的树,其三个指针域均为空,以方便接下来目录结构的读入和树型链表的构建。函数实现如下:Tree::Tree(stringName,intSize){this->Name=Name;this->Size=Size;FirstChild=NULL;//FirstChild域置空NextSibling=NULL;//NextSibling域置空parent=NULL;//Parent域置空}2.2.2析构函数析构函数的作用是删除同一个根节点下的各个子节点,以

18、释放空间。函数实现如下:Tree::~Tree(){

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

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

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