首頁 考試吧論壇 Exam8視線 考試商城 網(wǎng)絡課程 模擬考試 考友錄 實用文檔 求職招聘 論文下載
2011中考 | 2011高考 | 2012考研 | 考研培訓 | 在職研 | 自學考試 | 成人高考 | 法律碩士 | MBA考試
MPA考試 | 中科院
四六級 | 職稱英語 | 商務英語 | 公共英語 | 托福 | 雅思 | 專四專八 | 口譯筆譯 | 博思 | GRE GMAT
新概念英語 | 成人英語三級 | 申碩英語 | 攻碩英語 | 職稱日語 | 日語學習 | 法語 | 德語 | 韓語
計算機等級考試 | 軟件水平考試 | 職稱計算機 | 微軟認證 | 思科認證 | Oracle認證 | Linux認證
華為認證 | Java認證
公務員 | 報關員 | 銀行從業(yè)資格 | 證券從業(yè)資格 | 期貨從業(yè)資格 | 司法考試 | 法律顧問 | 導游資格
報檢員 | 教師資格 | 社會工作者 | 外銷員 | 國際商務師 | 跟單員 | 單證員 | 物流師 | 價格鑒證師
人力資源 | 管理咨詢師考試 | 秘書資格 | 心理咨詢師考試 | 出版專業(yè)資格 | 廣告師職業(yè)水平
駕駛員 | 網(wǎng)絡編輯
衛(wèi)生資格 | 執(zhí)業(yè)醫(yī)師 | 執(zhí)業(yè)藥師 | 執(zhí)業(yè)護士
會計從業(yè)資格考試會計證) | 經(jīng)濟師 | 會計職稱 | 注冊會計師 | 審計師 | 注冊稅務師
注冊資產評估師 | 高級會計師 | ACCA | 統(tǒng)計師 | 精算師 | 理財規(guī)劃師 | 國際內審師
一級建造師 | 二級建造師 | 造價工程師 | 造價員 | 咨詢工程師 | 監(jiān)理工程師 | 安全工程師
質量工程師 | 物業(yè)管理師 | 招標師 | 結構工程師 | 建筑師 | 房地產估價師 | 土地估價師 | 巖土師
設備監(jiān)理師 | 房地產經(jīng)紀人 | 投資項目管理師 | 土地登記代理人 | 環(huán)境影響評價師 | 環(huán)保工程師
城市規(guī)劃師 | 公路監(jiān)理師 | 公路造價師 | 安全評價師 | 電氣工程師 | 注冊測繪師 | 注冊計量師
繽紛校園 | 實用文檔 | 英語學習 | 作文大全 | 求職招聘 | 論文下載 | 訪談 | 游戲
您現(xiàn)在的位置: 考試吧(Exam8.com) > 軟件水平考試 > 復習資料 > 程序員資料 > 正文

2011年軟考程序員考試復習筆試知識點整理(20)

來源:考試吧Exam8.com) 2011-4-30 18:27:27 考試吧:中國教育培訓第一門戶 模擬考場
考試吧提供了“2011年軟考程序員考試復習筆試知識點整理”,供考生參考。

  更多:2011年軟考程序員考試復習筆試知識點整理匯總

  24、平衡二叉樹

  (1)定義:平衡二叉樹又被稱為AVL樹(區(qū)別于AVL算法),它是一棵二叉排序樹,且具有以下性質:它是一棵空樹或它的左右兩個子樹的高度差的絕對值不超過1,并且左右兩個子樹都是一棵平衡二叉樹。

  (2)構造與調整方法

  平衡二叉樹的常用算法有紅黑樹、AVL、Treap、伸展樹、左偏樹等。

  紅黑樹:紅黑樹是一種自平衡二叉查找樹,是在計算機科學中用到的一種數(shù)據(jù)結構,典型的用途是實現(xiàn)關聯(lián)數(shù)組。它是在1972年由Rudolf Bayer發(fā)明的,他稱之為"對稱二叉B樹",它現(xiàn)代的名字是在 LeoJ. Guibas 和 RobertSedgewick 于1978年寫的一篇論文中獲得的。它是復雜的,但它的操作有著良好的最壞情況運行時間,并且在實踐中是高效的: 它可以在O(log n)時間內做查找,插入和刪除,這里的n是樹中元素的數(shù)目。

  AVL:AVL是最先發(fā)明的自平衡二叉查找樹算法。在AVL中任何節(jié)點的兩個兒子子樹的高度最大差別為一,所以它也被稱為高度平衡樹。查找、插入和刪除在平均和最壞情況下都是O(log n)。增加和刪除可能需要通過一次或多次樹旋轉來重新平衡這個樹。

  Treap:Treap是一棵二叉排序樹,它的左子樹和右子樹分別是一個Treap,和一般的二叉排序樹不同的是,Treap紀錄一個額外的數(shù)據(jù),就是優(yōu)先級。Treap在以關鍵碼構成二叉排序樹的同時,還滿足堆的性質(在這里我們假設節(jié)點的優(yōu)先級大于該節(jié)點的孩子的優(yōu)先級)。但是這里要注意的是Treap和二叉堆有一點不同,就是二叉堆必須是完全二叉樹,而Treap可以并不一定是。

  伸展樹:伸展樹(Splay Tree)是一種二叉排序樹,它能在O(log n)內完成插入、查找和刪除操作。它由Daniel Sleator和Robert Tarjan創(chuàng)造。它的優(yōu)勢在于不需要記錄用于平衡樹的冗余信息。在伸展樹上的一般操作都基于伸展操作。

  左偏樹:堆結構是一種隱式數(shù)據(jù)結構(implicit data structure),用完全二叉樹表示的堆在數(shù)組中是隱式存貯的(即沒有明確的指針或其他數(shù)據(jù)能夠重構這種結構)。由于沒有存貯結構信息,這種描述方法空間利用率很高,事實上沒有空間浪費。盡管堆結構的時間和空間效率都很高,但它不適合于所有優(yōu)先隊列的應用,尤其是當需要合并兩個優(yōu)先隊列或多個長度不同的隊列時。因此需要借助于其他數(shù)據(jù)結構來實現(xiàn)這類應用,左偏樹(leftist tree)就能滿足這種要求。

  (3)平衡二叉樹

  為了保證二叉排序樹的高度為lgn,從而保證然二叉排序樹上實現(xiàn)的插入、刪除和查找等基本操作的平均時間為O(lgn),在往樹中插入或刪除結點時,要調整樹的形態(tài)來保持樹的"平衡。使之既保持BST性質不變又保證樹的高度在任何情況下均為O(lgn),從而確保樹上的基本操作在最壞情況下的時間均為O(lgn)。

  注意:

 �、倨胶舛鏄�(BalancedBinary Tree)是指樹中任一結點的左右子樹的高度大致相同。

  ②任一結點的左右子樹的高度均相同(如滿二叉樹),則二叉樹是完全平衡的。通常,只要二叉樹的高度為O(1gn),就可看作是平衡的。

 �、燮胶獾亩媾判驑渲笣M足BST性質的平衡二叉樹。

 �、蹵VL樹中任一結點的左、右子樹的高度之差的絕對值不超過1。在最壞情況下,n個結點的AVL樹的高度約為1.44lgn。而完全平衡的二叉樹度高約為lgn,AVL樹是接近最優(yōu)的。

  //AVL代碼

  #ifndefAVL_TREE_H

  #defineAVL_TREE_H

  #include"dsexceptions.h"

  #include // For NULL

  usingnamespace std;

  //AvlTree class

  //

  //CONSTRUCTION: with ITEM_NOT_FOUND object used to signal failed finds

  //

  //******************PUBLIC OPERATIONS*********************

  //void insert( x ) --> Insert x

  //void remove( x ) --> Remove x(unimplemented)

  //bool contains( x ) --> Return trueif x is present

  //Comparable findMin( ) --> Returnsmallest item

  //Comparable findMax( ) --> Returnlargest item

  //boolean isEmpty( ) --> Return trueif empty; else false

  //void makeEmpty( ) --> Remove allitems

  //void printTree( ) --> Print treein sorted order

  //******************ERRORS********************************

1 2 3 4 5 下一頁
  相關推薦:

  軟考程序員考試歷年真題重點題總結及答案

  2011年上半年軟考報名時間及方式匯總

  軟考程序員考試歷年真題匯總(2007年-2010年)

文章搜索
軟件水平考試欄目導航
版權聲明:如果軟件水平考試網(wǎng)所轉載內容不慎侵犯了您的權益,請與我們聯(lián)系800@exam8.com,我們將會及時處理。如轉載本軟件水平考試網(wǎng)內容,請注明出處。