高等院!笆濉焙诵恼n程輔導叢書:數(shù)據(jù)結構(C++版)答疑解惑與典型題解
定 價:35 元
- 作者:單憶南 ,唐軍軍 ,等 著
- 出版時間:2010/9/1
- ISBN:9787563522866
- 出 版 社:北京郵電大學出版社
- 中圖法分類:TP312C
- 頁碼:278
- 紙張:膠版紙
- 版次:1
- 開本:16開
《數(shù)據(jù)結構(C++版)答疑解惑與典型題解》是為熟悉C++編程的讀者學習數(shù)據(jù)結構而編寫的教學輔導書,可幫助讀者復習課程的基本內(nèi)容,并學會用C++使用相應的數(shù)據(jù)結構實現(xiàn)一定的算法和解決一些實際應用問題,力爭使讀者在學完《數(shù)據(jù)結構(C++版)答疑解惑與典型題解》之后,在課程的理解和掌握方面達到一個新的高度,《數(shù)據(jù)結構(C++版)答疑解惑與典型題解》也可供從事本課程教學的教師參考書。
《數(shù)據(jù)結構(C++版)答疑解惑與典型題解》共分十章,包括數(shù)據(jù)結構概述、線性表、棧和隊列、串和字符串、數(shù)組和廣義表、樹和二義樹、圖、查找、排序,在全書最后給出了一套模擬試題及參考答案。
《數(shù)據(jù)結構(C++版)答疑解惑與典型題解》每章內(nèi)容均包括各基本知識點的要點歸納,并精選一些經(jīng)典數(shù)據(jù)結構書中的經(jīng)典例題(包括課程考試試題、主流教材課后難題以及考研真題),給出了解題思路和分析方法,題后提示了解題中應注意的問題。力爭使讀者在盡可能短的時間內(nèi),鞏固課程基本概念,加深理解數(shù)據(jù)結構的基本知識并融會貫通,熟練掌握基本的編程方法并舉一反三,不斷提高讀者的C++編程能力和利用各種數(shù)據(jù)結構解決實際問題的能力。
《數(shù)據(jù)結構(C++版)答疑解惑與典型題解》可供學習數(shù)據(jù)結構課程(C++版)的讀者以及考研讀者和從事課程教學的教師參考。
《數(shù)據(jù)結構(C++版)答疑解惑與典型題解》特點: (1)結構清晰、模式合理!稊(shù)據(jù)結構(C++版)答疑解惑與典型題解》基本按照正規(guī)教學課本(主流教材)的順序安排,不是對所有知識點詳細鋪陳,而是對核心知識點和?碱}型做重點講解。每章設計了兩個板塊,分別是:答疑解惑與典型題解。各內(nèi)容安排為: 答疑解惑:突出核心知識,對重點、難點、易混淆的知識點進行剖析與解釋,讓學生掌握問題的本質(zhì)。包括對重要定理、定義和公式的剖析。 典型題解:精選出?碱}型與考研真題進行解析,增強學生的解題能力。《數(shù)據(jù)結構(C++版)答疑解惑與典型題解》每一章都列舉了大量的題目,并對其進行了詳細分析評注,以便于幫助讀者掌握本章的重點及迅速回憶本章的內(nèi)容。(題目來源:一是主流教材課后難題,二是課程考試試題,三是經(jīng)典好題,四是考研真題。) (2)針對性強、實用性強!稊(shù)據(jù)結構(C++版)答疑解惑與典型題解》不是按照傳統(tǒng)輔導書那種“內(nèi)容簡介-例題分析-習題”的模式編寫,而是在聽取大量一線教師和學生們建議的基礎上,以突出針對性與實用性來安排內(nèi)容的。學生們最需要的是解決他們學習過程中的“疑惑”以及掌握解題方法。《數(shù)據(jù)結構(C++版)答疑解惑與典型題解》正是以“答疑解惑與典型題解”為中心,因而具有很強的針對性與實用性。 (3)《數(shù)據(jù)結構(C++版)答疑解惑與典型題解》重點定位在疑難解惑與解題方法上,開拓解題思路,提高分析問題的能力,不僅授人以“魚”,更在于授人以“漁”。 (4)《數(shù)據(jù)結構(C++版)答疑解惑與典型題解》聘請執(zhí)教多年且有較高學術造詣的名師編寫,質(zhì)量高,內(nèi)容清晰。
本書是為熟悉C++的讀者學習數(shù)據(jù)結構而編寫的教學輔導書,可幫助讀者復習課程的基本內(nèi)容,檢驗各種數(shù)據(jù)結構形式和算法的掌握程度,培養(yǎng)和提高用C++解決實際問題的能力,力爭使讀者在學完本書之后,在運用數(shù)據(jù)結構解決實際問題和C++編程方面都達到一個新的高度。
1.本書閱讀指南
全書共分10章。
第l章主要介紹數(shù)據(jù)結構的基本概念,包括數(shù)據(jù)結構的應用、意義、時間復雜度、空間復雜度等內(nèi)容。
第2章主要介紹線性表這個數(shù)據(jù)結構類型,包括線性表達定義和基本概念、線性表的存儲、循環(huán)鏈表和雙向鏈表等內(nèi)容。
第3章主要介紹棧和隊列數(shù)據(jù)結構類型,包括棧的定義和基本操作、棧的存儲、隊列的定義和基本操作、隊列的存儲結構等內(nèi)容。
第4章主要介紹串數(shù)據(jù)結構類型,包括串的操作、串的模式匹配,以及KMP算法的理解等內(nèi)容。
第5章主要介紹數(shù)組與廣義表數(shù)據(jù)結構類型,包括多維數(shù)組、特殊矩陣的存儲、稀疏矩陣的存儲、廣義表的性質(zhì)和操作等內(nèi)容。
第6章主要介紹樹與二叉樹數(shù)據(jù)結構類型,包括樹和二叉樹的性質(zhì)和定義、二叉樹的遍歷、表達式的二又樹表示、線索化二又樹、樹和森林、哈夫曼樹等內(nèi)容。
第7章主要介紹圖數(shù)據(jù)結構類型,包括圖的基本性質(zhì)和概念、圖的存儲、圖的遍歷、圖的連同性、最小生成樹算法、最短路徑問題、拓撲排序等內(nèi)容。
第8章主要介紹查找操作及相應的數(shù)據(jù)結構,包括查找的定義、順序查找、折半查找、分塊查找、二叉排序樹、平衡二叉樹、B一樹、哈希表和散列表等內(nèi)容。
第9章主要介紹排序操作及應用的數(shù)據(jù)結構,包括排序的概念、插入排序、冒泡排序、選擇排序、歸并排序、基數(shù)排序、幾種內(nèi)部排序時間復雜度空間復雜度的比較和外部排序等內(nèi)容。
第10章給出一套課程測試和一套研究生入學考試全真預測試題及參考答案。
2.本書的特色與優(yōu)點
本書編寫的指導思想是:在內(nèi)容上重視數(shù)據(jù)結構的基本理論,利用C++作為程序語言進行描述,覆蓋課程全部基本教學要求;書中習題主要來自于經(jīng)典數(shù)據(jù)結構教材中的經(jīng)典習題,全書習題經(jīng)過編者精挑細選,難度適中,適合各專業(yè)學習本課程的學生;在形式上根據(jù)教學實踐經(jīng)驗和對相關內(nèi)容的思考理解,簡明描述課程的基本知識點、重點和難點內(nèi)容,使學生迅速把握重點。
第1章 數(shù)據(jù)結構基本概念
1.1 答疑解惑
1.1.1 為什么要用數(shù)據(jù)類型來描述數(shù)據(jù)結構?
1.1.2 何為抽象數(shù)據(jù)類型(ADT)?
1.1.3 算法和程序有何區(qū)別?
1.1.4 怎樣理解數(shù)據(jù)的邏輯結構和存儲結構?
1.1.5 怎樣理解數(shù)據(jù)結構在計算機課程中的核心地位?
1.1.6 如何計算算法的時間復雜度?
1.1.7 如何評價算法的好壞?
1.2 典型題解
題型1 數(shù)據(jù)結構基礎知識
題型2 時間與空間復雜度的計算
第2章 線性表
2.1 答疑解惑
2.1.1 如何理解線性表數(shù)據(jù)結構?
2.1.2 線性表的順序存儲結構和鏈式存儲結構的區(qū)別是什么?
2.1.3 帶頭結點的單鏈表和不帶頭結點的單鏈表的區(qū)別是什么?
2.1.4 鏈表的指針修改的次序對結果的影響是什么?
2.1.5 各種鏈表存儲結構的特點是什么?
2.1.6 如何利用循環(huán)單鏈表實現(xiàn)隊列的操作?
2.1.7 如何應用線性表?
2.1.8 順序表的聲明和基本運算用C++如何描述?
2.2 典型題解
題型1 線性表的基本概念
題型2 線性表的存儲結構
題型3 鏈表的插入和刪除
題型4 線性表元素查找
題型5 遞歸
題型6 歸并
題型7 單鏈表的應用
題型8 其他鏈表及應用
第3章 棧與隊列
3.1 答疑解惑
3.1.1 怎樣理解棧?
3.1.2 棧的順序存儲結構和鏈式存儲結構的區(qū)別是什么?
3.1.3 在進行人棧和出棧時應注意的問題是什么?
3.1.4 如何理解多棧的作用?
3.1.5 兩個棧如何共享同一存儲空間?
3.1.6 如何應用棧?
3.1.7 怎樣理解隊列?
3.1.8 如何處理循環(huán)隊列中的邊界條件?
3.1.9 隊列的順序存儲結構和鏈式存儲結構的區(qū)別是什么?
3.1.10 如何理解雙隊列的作用?
3.1.11 如何應用隊列?
3.2 典型題解
題型1 棧和隊列的基本概念
題型2 棧和隊列的基本操作
題型3 棧和隊列的狀態(tài)分析
題型4 遞歸算法和遞歸工作棧
題型5 用棧求表達式的值
題型6 棧和隊列的應用
第4章 串
4.1 答疑解惑
4.1.1 怎樣理解串?
4.1.2 串的順序存儲結構和鏈式存儲結構的優(yōu)缺點是什么?
4.1.3 串的基本操作
4.1.4 怎樣用共享堆求子串?
4.1.5 如何理解KMP算法?
4.1.6 串有何應用?
4.2 典型題解
題型1 串的性質(zhì)和存儲
題型2 串的基本運算
題型3 串的模式匹配
第5章 數(shù)組與廣義表
5.1 答疑解惑
5.1.1 數(shù)組存儲地址如何確定?
5.1.2 對稱矩陣如何壓縮存儲?
5.1.3 對稱矩陣的地址計算公式是什么?
5.1.4 三角矩陣如何壓縮存儲?
5.1.5 對角矩陣的概念是什么?
5.1.6 稀疏矩陣的三元組存儲結構如何理解?
5.1.7 如何靈活運用廣義表的表頭和表尾操作?
5.1.8 如何由廣義表表示得到其動態(tài)存儲表示?
5.1.9 如何由廣義表的動態(tài)存儲表示求廣義表表示?
5.1.10 廣義表如何運算?
5.1.11 如何理解廣義表表示和二叉樹的內(nèi)在聯(lián)系?
5.2 典型題解
題型1 多維數(shù)組
題型2 特殊矩陣
題型3 稀疏矩陣
題型4 廣義表
第6章 樹與二叉樹
6.1 答疑解惑
6.1.1 樹的遞歸定義如何理解?
6.1.2 如何理解樹的性質(zhì)和基本概念?
6.1.3 如何理解二叉樹的性質(zhì)及其推廣?
6.1.4 如何理解二叉樹遍歷的非遞歸?
6.1.5 如何理解線索二叉樹實現(xiàn)二叉樹的非遞歸?
6.1.6 如何理解二叉樹中序線索化的算法?
6.1.7 二叉樹與樹或森林轉換的目的是什么?
6.1.8 建立二又樹有哪些方法?
6.1.9 森林的兩種遍歷都是哪些?
6.1.10 如何理解廣義表表示和二叉樹的內(nèi)在聯(lián)系?
6.1.11 哈夫曼樹的建立和哈夫曼編碼的構造?
6.1.12 如何用二又樹表示表達式?
6.2 典型題解
題型1 樹的性質(zhì)
題型2 二叉樹的性質(zhì)
題型3 條件運算
題型4 二叉樹的遍歷
題型5 根據(jù)遍歷結果還原樹
題型6 線索二叉樹
題型7 樹與森林
題型8 樹與森林
第7章 圖
7.1 答疑解惑
7.1.1 如何理解圖的定義?
7.1.2 如何理解圖的各種存儲結構?
7.1.3 如何理解圖的遍歷?
7.1.4 如何理解圖遍歷的非遞歸算法?
7.1.5 如何理解圖的最小生成樹?
7.1.6 如何用圖的框架及其遍歷方法解決背包問題?
7.1.7 如何理解拓撲排序的作用?
7.1.8 如何理解Dikstra算法和F1oy算法的優(yōu)缺點?
7.1.9 如何理解關鍵路徑?
7.1.10 圖的應用有哪些?
7.2 典型題解
題型1 圖的基本概念
題型2 圖的存儲結構
題型3 圖的遍歷
題型4 圖的生成樹
題型5 圖的最短路
題型6 圖的拓撲排序
題型7 圖的應用
第8章 查找
8.1 答疑解惑
8.1.1 如何理解查找的基本概念?
8.1.2 如何理解順序查找中的監(jiān)視哨作用?
8.1.3 如何理解平均查找長度?
8.1.4 折半查找的前提條件及其優(yōu)缺點有哪些?
8.1.5 什么情況下使用分塊查找
8.1.6 二叉排序樹的特點有哪些?
8.1.7 如何調(diào)整平衡二叉樹?
8.1.8 深刻理解B一樹的定義及其動態(tài)調(diào)整
8.1.9 如何理解散列表的性質(zhì)?
8.1.10 如何理解散列表的沖突?
8.1.11 常用的散列函數(shù)有哪些?
8.2 典型題解
題型1 順序查找
題型2 二分查找
題型3 一維數(shù)組元素的移動
題型4 一維數(shù)組的排序
題型5 平衡二叉樹
題型6 B樹
題型7 哈希表
第9章 排序
9.1 答疑解惑
9.1.1 如何理解排序算法的穩(wěn)定性?
9.1.2 內(nèi)部排序和外部排序有什么區(qū)別?
9.1.3 如何將順序存儲結構上的排序算法移植到鏈表上?
9.1.4 希爾排序為何比一般的插入排序要高效?
9.1.5 如何理解堆排序?
9.1.6 如何在r進制下運用基數(shù)排序?
9.1.7 如何合理地采用適當?shù)膬?nèi)部排序方法?
9.1.8 如何在^路歸并方法中使用敗者樹?
9.2 典型題解
題型1 排序基本概念
題型2 插人排序
題型3 冒泡排序
題型4 選擇排序
題型5 歸并排序
題型6 基數(shù)排序
題型7 各種內(nèi)部排序的比較
題型8 外部排序
第10章 課程測試與考研真題
10.1 課程測試
10.2 考研真題
10.3 課程測試解析
10.4 考研真題解析
參考文獻
采用數(shù)據(jù)類型來描述數(shù)據(jù)結構是基于以下考慮:
(1)數(shù)據(jù)類型(Data Type)是一個值的集合和定義在這個值集上的一組操作的總稱。解決現(xiàn)實問題就必須進行數(shù)據(jù)處理,而數(shù)據(jù)處理包括對數(shù)據(jù)進行查找、插入、刪除、合并、排序、統(tǒng)計以及簡單計算等的操作過程。
(2)數(shù)據(jù)類型是高級程序設計語言中的一個基本概念,它和數(shù)據(jù)結構的概念密切相關。一方面,在程序設計語言中,每一個數(shù)據(jù)都屬于某種數(shù)據(jù)類型。類型明顯或隱含地規(guī)定了數(shù)據(jù)的取值范圍、存儲方式以及允許進行的運算?梢哉J為,數(shù)據(jù)類型是在程序設計中已經(jīng)實現(xiàn)了的數(shù)據(jù)結構。另一方面,在程序設計過程中,當需要引入某種新的數(shù)據(jù)結構時,總是借助編程語言所提供的數(shù)據(jù)類型來描述數(shù)據(jù)的存儲結構。
(3)用高級語言數(shù)據(jù)類型來描述數(shù)據(jù)結構,更避免了低級語言的復雜性,增加了可讀性和簡潔性,又有利于算法的實現(xiàn)。