999精品在线视频,手机成人午夜在线视频,久久不卡国产精品无码,中日无码在线观看,成人av手机在线观看,日韩精品亚洲一区中文字幕,亚洲av无码人妻,四虎国产在线观看 ?

數據結構中樹的遍歷課程設計與實現

2017-02-01 10:51:24田曉輝
文化創新比較研究 2017年12期
關鍵詞:結構信息

田曉輝

(渭南師范學院網絡安全與信息化學院, 陜西渭南 714099)

1 樹形結構

1.1 樹的定義[1]

一棵有根樹T,簡稱為樹,可定義為n(n≥0)個結點的有限集合。當n=0時,T稱為空樹;否則,T是非空樹,記作:

1.2 樹的存儲結構

樹的主要存儲結構有以下三種[2]:

[1]雙親表示法:

用一組連續的空間來存儲樹中的結點,在保存每個結點的同時附設一個指示器來指示其雙親結點在表中的位置。

[2]孩子表示法

把每個結點的孩子結點排列起來,構成一個單鏈表,稱為孩子鏈表。n個結點共有n 個孩子鏈表(葉子結點的孩子鏈表為空表),而 n 個結點的數據和 n個孩子鏈表的頭指針又組成一個順序表。

[3]孩子兄弟表示法

這種表示法又稱為樹的二叉表示法,或者二叉鏈表表示法,即以二叉鏈表作為樹的存儲結構。鏈表中每個結點設有兩個鏈域,分別指向該結點的第一個孩子結點和下一個兄弟(右兄弟)結點。

2 課程設計

2.1 問題描述

給出某操作系統的目錄和文件信息,編程將其以樹狀結構顯示。輸入的信息有兩種,第一種為目錄信息。目錄下面可以存放文件或子目錄,即目錄結點可能存在孩子結點,若存在,其孩子結點信息要求在該目錄信息的下一行給出,孩子結點信息要求用圓括號“()”括起。目錄的輸入格式為:[目錄名稱]大小。第二種是文件信息。輸入格式為:文件名稱 大小。目錄名或文件名為長度小于等于10的字符串,且目錄名或文件名不能包含‘(’,‘)’和‘*’。目錄的“大小”都表示為 1,文件的“大小”輸入值為文件的實際大小。

編程實現如下輸出,要求是有層次結構的樹,每層結點(目錄結點或文件結點)都要比上一層結點多縮進多個空格。同層目錄或文件結點在同一列顯示。計算所有目錄的大小(為其子目錄大小+子文件大小+1),并在目錄名和文件后面顯示各自大小。

2.2 算法思想

本文對目錄樹采用孩子兄弟鏈表法結合雙親法的存儲結構,根據輸入的目錄和文件信息,先創建樹,再把孩子兄弟存儲結構的樹以顯式的樹狀結構輸出,每個結點要按其所在層次作相應的縮進。其中,創建樹采用層序遍歷算法實現,輸出樹采用先序遍歷算法實現。若某結點的第一個孩子結點有右孩子結點(兄弟結點),則需要按其所在層次進行縮進后輸出連接符|和多個空格;否則只輸出多個空格;計算某目錄的大小時,為該目錄結點的左子樹(以其第一個孩子為根的樹)所有結點的“大小”的和再加該目錄的“大小”。

3 實現

3.1 樹的存儲結構

在輸出樹結構時,由于先輸出的是同一層結點的第一個結點及其對應的子樹,再輸出同一層結點的第二個結點及其對應的子樹,所以,使用孩子兄弟鏈表存儲結構時,用先序遍歷算法遍歷該結構,剛好可以實現上面的輸出順序的要求;其次,由于每一個目錄結點(雙親結點)下面可能存在子目錄或文件結點(孩子結點),在縮進處理上,輸出子目錄或文件結點信息時,要比其雙親的目錄結點信息縮進更多,為了便于處理縮進,在孩子兄弟存儲結構中增加了parent 域,得到了改進后的孩子兄弟存儲結構[3]。

3.2 關鍵算法的設計

(1)創建樹的改進孩子兄弟存儲結構:

首先讀入根目錄名稱和大小,創建根結點,將根結點的三個指針域置空;

讀入下一行目錄或文件信息并創建結點。創建新結點,該結點是根結點的第一孩子結點,建立其和根結點的鏈接。然后循環做如下的操作:若本行后面還有文件或目錄信息,建立新結點,建立其和雙親結點的鏈接,建立其和前一兄弟結點的鏈接。將該結點的“大小”值加到根結點的“大小”中去。重復該過程,直到本行信息讀取結束。

重復上面的過程,直到整體輸入結束。

(2)輸出樹:

設當前指針(位置)為根目錄,先輸出根結點;

將當前指針改為根結點的第一孩子結點

循環做如下操作:

輸出當前指針對應的結點及其子樹;

將當前指針移向當前指針的下一兄弟結點;

直至當前指針為空。

4 測試

運行程序時,輸入異常的測試數據時,提示“Input Error!”。輸入正確的測試數據:

得到如下圖1所示結果。

圖1 樹型結構

[1]殷人昆.數據結構C語言描述[M].北京:機械工業出版社,2011.6:108-109

[2]耿國華.數據結構(用 C語言描述)[M].北京:高等教育出版社.2016:181-183

[3]何欽銘,陳根才.數據結構課程設計[M].杭州:浙江大學出版社,2015.8:24-41

猜你喜歡
結構信息
《形而上學》△卷的結構和位置
哲學評論(2021年2期)2021-08-22 01:53:34
論結構
中華詩詞(2019年7期)2019-11-25 01:43:04
新型平衡塊結構的應用
模具制造(2019年3期)2019-06-06 02:10:54
訂閱信息
中華手工(2017年2期)2017-06-06 23:00:31
論《日出》的結構
創新治理結構促進中小企業持續成長
現代企業(2015年9期)2015-02-28 18:56:50
展會信息
中外會展(2014年4期)2014-11-27 07:46:46
基于BIM的結構出圖
信息
建筑創作(2001年3期)2001-08-22 18:48:14
健康信息
祝您健康(1987年3期)1987-12-30 09:52:32
主站蜘蛛池模板: 国产精品网拍在线| 亚洲三级a| 扒开粉嫩的小缝隙喷白浆视频| 欧美www在线观看| 欧洲熟妇精品视频| 欧美国产日产一区二区| 国产成人亚洲综合A∨在线播放| 青青操视频在线| 55夜色66夜色国产精品视频| 国产91在线免费视频| 日韩免费成人| 性欧美在线| 日韩一区二区三免费高清| 国产精品亚洲五月天高清| 久久网欧美| 97国产精品视频自在拍| 国产理论一区| 日韩精品亚洲人旧成在线| 国产99精品久久| 亚洲AⅤ波多系列中文字幕| 国产无吗一区二区三区在线欢| 波多野结衣视频一区二区 | 国产丝袜第一页| 久久人午夜亚洲精品无码区| 看av免费毛片手机播放| a毛片在线| 亚洲日韩精品伊甸| 午夜激情婷婷| 日韩无码黄色网站| 久久精品91麻豆| 国产黄视频网站| 亚洲成人在线免费观看| 99在线国产| 极品尤物av美乳在线观看| 国产午夜人做人免费视频中文| 91国内在线视频| 中文字幕乱码中文乱码51精品| 色婷婷视频在线| 欧美日韩精品在线播放| 国产在线观看第二页| 试看120秒男女啪啪免费| 69av在线| 午夜免费视频网站| 亚洲精品卡2卡3卡4卡5卡区| 九九香蕉视频| 二级特黄绝大片免费视频大片| 91口爆吞精国产对白第三集| 亚洲综合激情另类专区| 永久在线精品免费视频观看| 青草娱乐极品免费视频| 午夜啪啪福利| 国产精品视频a| 亚洲国模精品一区| 国产成人8x视频一区二区| 99精品福利视频| 成年A级毛片| 成人第一页| 99在线观看精品视频| 久青草免费在线视频| 女同久久精品国产99国| 亚洲欧美另类日本| 日本AⅤ精品一区二区三区日| 又大又硬又爽免费视频| 免费在线视频a| a毛片免费看| 97se亚洲综合在线| 亚洲成人精品久久| 黄色污网站在线观看| 国产超碰在线观看| 国产精品青青| 亚洲精品爱草草视频在线| 国产精品一线天| 国产黄色视频综合| 911亚洲精品| 久久综合色播五月男人的天堂| 亚洲狼网站狼狼鲁亚洲下载| 1769国产精品视频免费观看| 久久精品只有这里有| jijzzizz老师出水喷水喷出| 国产无码精品在线播放| 狠狠色综合久久狠狠色综合| 婷婷色一二三区波多野衣|