共找到2條詞條名為數據結構與演算法分析的結果 展開

數據結構與演演算法分析

Java語言描述第2版

《數據結構與演演算法分析(Java語言描述)(第2版)》是2007年出版的圖書,作者是Frank Carrano。

圖書簡介


本書是為數據結構入門課程(通常課號是CS-2)而編寫的教材。作者Frank Carrano在編寫過程自始至終特別考慮到了Java與對象,為教師和學生提供了一種精心設計並經過教學實驗的方式藉助Java講授ADT和對象。本書獨特的設計將內容組織為相對較短的章。這種方式使學習更容易,並留出了教學的機動性。本書教給學生如何使用線性表、詞典、棧、隊列等等來組織數據。利用這些數據組織方式,學生們將學到演演算法設計的相關技術。書中的“編程提示”給讀者額外的編程建議;大量的插圖使講解更形象生動;自測題貫穿各章,書末還給出了答案。本書適合作為數據結構的教學用書。
“數據結構”是計算機專業的基礎與核心課程之一,也是從事軟體開發必不可少的入門和常用知識。
程序編寫得好不好,很大程度上取決於編程者對數據結構是否熟練地掌握和恰當地運用。
由於它不僅重要,而且易學難精,“數據結構”一直都被列入相關專業的研究生入學考試和相關行業的公司招聘考試的重點考查範圍。
由於“數據結構”這門課程本身的特點,它必須依託於一種程序設計語言才能講授,否則就成了空中樓閣、紙上談兵。因此,儘管從抽象和邏輯的角度看來都大同小異,按照所依託的程序設計語言可以把“數據結構”的教材分為不同的版本--諸如Pascal版、C版、C++版以及Java版。
除了由於程序設計語言的不同特性而導致的程序實現上的差異,不同版本的“數據結構”教材所講述的主要內容並無本質區別。因此,初學者可以根據自己已經掌握的或者將作為主要使用的程序設計語言選擇相應版本的“數據結構”教材來學習。
將來如果換用另一種程序設計語言,也不需要重新學習另一個版本的“數據結構”教材,只需將其作為參考,查閱同樣的數據結構是如何用另一種語言實現的即可。這也是為什麼不同版本的“數據結構”教材都有其存在的意義。

圖書目錄


引言1
第1章 Java類2
1.1 對象與類2
1.2 在Java類中使用方法5
1.3 定義Java類7
1.3.1 方法定義8
1.3.2 實參與形參10
1.3.3 傳遞實參11
1.3.4 Name類的定義14
1.3.5 構造函數16
1.3.6 toString方法18
1.3.7 調用其他方法的方法 …18
1.3.8 返回所屬類實例
的方法20
1.3.9 靜態域與靜態方法20
1.3.10 方法的重載22
1.4 枚舉類23
1.5 包26
本章小結27
練習28
項目設計31
第2章 從已有類創建新類35
2.1 合成35
2.1.1 通用類型38
2.1.2 適配器41
2.2 繼承42
2.2.1 從構造函數中調用構造
函數45
2.2.2 基類的私有域與私有
方法46
2.2.3 受保護的訪問47
2.2.4 方法的覆蓋與重載47
2.2.5 多重繼承52
2.3 類型兼容性與基類53
2.3.1 Object類54
2.3.2 抽象類與抽象方法56
2.4 多態性58
本章小結63
練習64
項目設計68
第3章 類的設計70
3.1 封裝70
3.2 方法的說明72
3.3 介面76
3.3.1 編寫介面76
3.3.2 實現介面78
3.3.3 作為數據類型的
介面79
3.3.4 介面的通用類型80
3.3.5 Comparable介面80
3.3.6 擴展介面82
3.3.7 介面與抽象類83
3.3.8 符號常量85
3.4 類的選擇86
3.4.1 類的確定87
3.4.2 CRC卡片88
3.5 類的復用91
本章小結91
練習92
項目設計93
第4章 線性表96
4.1 ADT線性表說明96
4.2 使用ADT線性表103
4.3 像使用自動售貨機一樣使用
線性表107
4.4 Java類庫:List介面109
本章小結109
練習110
項目設計112
第5章 用數組實現線性表114
5.1 使用定長數組實現ADT
線性表114
5.1.1 類比114
5.1.2 Java實現116
5.2 使用動態擴展數組實現
ADT線性表124
5.2.1 擴展數組125
5.2.2 線性表的新實現127
5.3 Java類庫:ArrayList與
Vector類128 5.4 用數組實現ADT線性表的優缺點132
本章小結133
練習134
項目設計135
目 錄 數據結構與演演算法分析(Java語言描述)(第2版)第6章 用鏈表實現線性表136
6.1 鏈表136
6.1.1 在表頭添加來創建鏈表137
6.1.2 在表末添加來創建鏈表138
6.1.3 在不同位置添加來創建鏈表 …140
6.2 使用鏈表實現ADT線性表142
6.2.1 私有類Node142
6.2.2 數據域與構造函數144
6.2.3 選擇要實現的核心方法組145
6.2.4 在線性表的末端插入元素146
6.2.5 在線性表的指定位置插入
元素148
6.2.6 私有方法getNodeAt152
6.2.7 斷言與isEmpty方法153
6.2.8 display方法154
6.3 測試不完整的實現155
本章小結157
練習158
項目設計159
第7章 完成線性表的鏈表實現160
7.1 從鏈表中刪除一個元素160
7.2 完成ADT線性表的鏈表實現162
7.2.1 方法remove162
7.2.2 方法replace165
7.2.3 方法getEntry165
7.2.4 方法contains166
7.2.5 其他方法166
7.3 使用具有設置與獲取方法的
Node類167
7.4 表尾引用170
7.5 用鏈表實現ADT線性表的優缺點175
7.6 Java類庫:LinkedList類175
本章小結176
練習176
項目設計177
第8章 迭代器179
8.1 什麼是迭代器179
8.2 Iterator介面180
8.3 獨立類迭代器186
8.4 內部類迭代器189
8.4.1 基於鏈表實現190
8.4.2 基於數組實現194
8.5 迭代器方法為何在自己的類中197
8.6 ListIterator介面198
8.7 基於數組實現ListIterator介面204
8.8 Java類庫:Iterable介面211
8.8.1 Iterable與for-each循環212
8.8.2 重溫List介面212
本章小結213
練習213
項目設計216
第9章 演演算法的效率218
9.1 動機218
9.2 度量演演算法的效率220
9.3 形式化226
9.4 效率的圖形表示229
9.5 ADT線性表不同實現的效率232
9.5.1 基於數組實現232
9.5.2 基於鏈表實現234
9.5.3 比較上述實現237
本章小結238
練習238
項目設計240
第10章 遞歸243
10.1 何謂遞歸243
10.2 跟蹤遞歸方法248
10.3 有返回值的遞歸方法250
10.4 遞歸處理數組253
10.5 遞歸處理鏈表255
10.6 遞歸方法的時間效率257
10.6.1 countDown的時間效率257
10.6.2 計算xn的時間效率258
10.7 困難問題的簡單解法259
10.8 簡單問題的拙劣解法264
10.9 尾遞歸266
10.10 協同遞歸268
本章小結268
練習270
項目設計271
第11章 排序入門275
11.1 組織用於數組排序的Java方法276
11.2 選擇排序277
11.2.1 迭代選擇排序278
11.2.2 遞歸選擇排序280
11.2.3 選擇排序的效率281
11.3 插入排序282
11.3.1 迭代插入排序283
11.3.2 遞歸插入排序284
11.3.3 插入排序的效率286
11.3.4 鏈表的插入排序286
11.4 希爾排序289
11.4.1 Java代碼291
11.4.2 希爾排序的效率292
11.5 演演算法比較293
本章小結293
練習293
項目設計296
第12章 快速排序演演算法298
12.1 歸併排序298
12.1.1 數組的歸併298
12.1.2 遞歸歸併排序299
12.1.3 歸併排序的效率302
12.1.4 迭代歸併排序303
12.1.5 Java類庫中的歸併排序304
12.2 快速排序304
12.2.1 快速排序的效率305
12.2.2 創建劃分305
12.2.3 快速排序的Java代碼308
12.2.4 Java類庫中的快速排序311
12.3 基數排序311
12.3.1 基數排序的偽代碼313
12.3.2 基數排序的效率313
12.4 演演算法比較314
本章小結314
練習315
項目設計316
第13章 有序表319
13.1 ADT有序表的說明319
13.2 鏈表實現323
13.2.1 add方法324
13.2.2 鏈表實現的效率331
13.3 使用ADT線性表的實現331
本章小結336
練習336
項目設計337
第14章 繼承與線性表339
14.1 使用繼承實現有序表339
14.2 設計一個基類342
14.3 有序表的一種高效實現348
本章小結349
練習350
項目設計350
第15章 可變對象、不可變對象與可克隆
對象352
15.1 可變對象與不可變對象352
15.1.1 創建只讀類355
15.1.2 同伴類356
15.2 可克隆對象358
15.2.1 克隆數組364
15.2.2 克隆鏈表366
15.2.3 克隆體的有序表370
本章小結373
練習373
項目設計376
第16章 查找377
16.1 問題描述377
16.2 查找無序數組378
16.2.1 迭代順序查找無序數組378
16.2.2 遞歸順序查找無序數組379
16.2.3 順序查找數組的效率381
16.3 查找有序數組381
16.3.1 順序查找有序數組381
16.3.2 折半查找有序數組382
16.3.3 Java類庫: binarySearch
方法386
16.3.4 折半查找數組的效率387
16.4 查找無序鏈表388
16.4.1 迭代順序查找無序鏈表388
16.4.2 遞歸順序查找無序鏈表389
16.4.3 順序查找鏈表的效率390
16.5 查找有序鏈表390
16.5.1 順序查找有序鏈表390
16.5.2 折半查找有序鏈表391
16.6 查找方法的選擇391
本章小結392
練習392
項目設計394
第17章 詞典396
17.1 ADT詞典的說明396
17.1.1 Java介面399
17.1.2 迭代器400
17.2 使用ADT詞典402
17.2.1 電話號碼簿402
17.2.2 詞頻407
17.2.3 詞的索引411
17.3 Java類庫:Map介面414
本章小結415
練習415
項目設計416
第18章 詞典的實現418
18.1 基於數組的實現418
18.1.1 基於數組的無序詞典419
18.1.2 基於數組的有序詞典424
18.2 基於向量的實現428
18.3 基於鏈表的實現433
18.3.1 基於鏈表的無序詞典434
18.3.2 基於鏈表的有序詞典434
本章小結438
練習438
項目設計439
第19章 散列概述440
19.1 什麼是散列440
19.2 散列函數442
19.2.1 計算散列碼443
19.2.2 將散列碼壓縮為散列表的
索引445
19.3 處理衝突446
19.3.1 線性探測開放定址446
19.3.2 二次探測開放定址451
19.3.3 雙散列開放定址451
19.3.4 開放定址的潛在問題453
19.3.5 鏈地址453
本章小結456
練習457
項目設計458
第20章 用散列實現詞典459
20.1 效率459
20.1.1 裝填因子460
20.1.2 開放定址的開銷460
20.1.3 鏈地址的開銷462
20.2 再散列463
20.3 處理衝突的各方案比較464
20.4 使用散列的詞典實現465
20.4.1 散列表中的元素465
20.4.2 數據域與構造函數466
20.4.3 方法getValue、remove
和add467
20.4.4 迭代器473
20.5 Java類庫:類HashMap475
本章小結475
練習476
項目設計476
第21章 棧478
21.1 ADT棧的說明478
21.2 利用棧處理代數表達式481
21.2.1 檢查中綴代數表達式的括弧
是否平衡482
21.2.2 將中綴表達式轉化為後綴
表達式487
21.2.3 後綴表達式求值493
21.2.4 中綴表達式求值495
21.3 程序棧497
21.4 使用棧代替遞歸498
21.5 Java類庫:類Stack501
本章小結502
練習502
項目設計504
第22章 棧的實現506
22.1 基於鏈表的實現506
22.2 基於數組的實現509
22.3 基於向量的實現513
本章小結515
練習515
項目設計516
第23章 隊列、雙端隊列與優先隊列517
23.1 ADT隊列的描述517
23.2 使用隊列模擬排隊521
23.3 使用隊列計算股份銷售的資本
收益527
23.4 Java類庫:Queue介面530
23.5 ADT雙端隊列的描述530
23.6 使用雙端隊列計算股份銷售的資本
收益532
23.7 ADT優先隊列的描述534
23.8 使用優先隊列跟蹤委派任務535
本章小結537
練習537
項目設計539
第24章 隊列、雙端隊列與優先隊列的
實現541
24.1 基於鏈表的隊列實現541
24.2 基於數組的隊列實現545
24.2.1 循環數組546
24.2.2 含有一個未用位置的循環
數組547
24.3 基於向量的隊列實現552
24.4 基於循環鏈表的隊列實現554
24.5 Java類庫:AbstractQueue類560
24.6 基於雙向鏈表的雙端隊列實現560
24.7 實現優先隊列的可用方法564
24.8 Java類庫:PriorityQueue類564
本章小結565
練習566
項目設計567
第25章 樹569
25.1 樹的概念569
25.1.1 層次化的組織569
25.1.2 樹的術語571
25.2 樹的遍歷574
25.2.1 二叉樹的遍歷575
25.2.2 樹的遍歷576
25.3 樹的Java介面577
25.3.1 所有樹的介面577
25.3.2 二叉樹的介面578
25.4 二叉樹舉例579
25.4.1 表達式樹580
25.4.2 決策樹581
25.4.3 二叉查找樹585
25.4.4 堆587
25.5 樹舉例589
25.5.1 語法分析樹589
25.5.2 博弈樹590
本章小結590
練習591
項目設計593
第26章 樹的實現595
26.1 二叉樹的結點595
26.1.1 結點的介面596
26.1.2 BinaryNode的實現597
26.2 ADT二叉樹的實現599
26.2.1 創建基本二叉樹599
26.2.2 方法privateSetTree600
26.2.3 訪問者與修改者方法603
26.2.4 計算高度與統計結點604
26.2.5 遍歷605
26.3 表達式二叉樹的實現610
26.4 樹612
26.4.1 樹的結點612
26.4.2 用二叉樹表示樹613
本章小結614
練習614
項目設計616
第27章 二叉查找樹的實現617
27.1 預備知識617
27.1.1 二叉查找樹介面618
27.1.2 重複元素620
27.1.3 開始類定義621
27.2 查找與檢索622
27.3 遍歷624
27.4 插入元素624
27.4.1 遞歸實現625
27.4.2 迭代實現628
27.5 刪除元素631
27.5.1 刪除葉子結點中的元素631
27.5.2 刪除有一個孩子的結點中的
元素631
27.5.3 刪除有兩個孩子的結點中的
元素631
27.5.4 刪除根結點中的元素635
27.5.5 遞歸實現635
27.5.6 迭代實現639
27.6 操作的效率643
27.6.1 平衡的重要性644
27.6.2 插入結點的順序644
27.7 ADT詞典的實現645
本章小結648
練習649
項目設計651
第28章 堆的實現653
28.1 再論ADT堆653
28.2 用數組表示堆654
28.3 插入元素656
28.4 刪除根659
28.5 創建堆662
28.6 堆排序664
本章小結667
練習668
項目設計669
第29章 平衡查找樹670
29.1 AVL樹670
29.1.1 單旋轉671
29.1.2 雙旋轉673
29.1.3 實現細節676
29.2 2-3樹681
29.2.1 2-3樹的查找681
29.2.2 往2-3樹插入元素682
29.2.3 插入期間分裂結點683
29.3 2-4樹685
29.3.1 往2-4樹插入元素685
29.3.2 比較AVL樹、2-3樹
和2-4樹 686
29.4 紅黑樹687
29.4.1 紅黑樹的特性688
29.4.2 往紅黑樹插入元素689
29.4.3 Java類庫:類TreeMap693
29.5 B樹693
本章小結694
練習695
項目設計696
第30章 圖697
30.1 一些例子與術語697
30.1.1 公路地圖697
30.1.2 航線700
30.1.3 迷宮700
30.1.4 先修課程701
30.1.5 樹701
30.2 遍歷701
30.2.1 廣度優先遍歷702
30.2.2 深度優先遍歷704
30.3 拓撲順序705
30.4 路徑707
30.4.1 尋找路徑708
30.4.2 無權圖的最短路徑708
30.4.3 加權圖的最短路徑710
30.5 ADT圖的Java介面714
本章小結717
練習718
項目設計720
第31章 圖的實現722
31.1 兩種實現的概述722
31.1.1 鄰接矩陣722
31.1.2 鄰接表723
31.2 頂點與邊724
31.2.1 說明類Vertex724
31.2.2 內部類Edge726
31.2.3 實現Vertex類727
31.3 ADT圖的實現731
31.3.1 基本操作731
31.3.2 圖的演演算法735
本章小結737
練習738
項目設計739
附錄A Java基礎741
A.1 引言741
A.1.1 應用程序和小程序741
A.1.2 對象和類741
A.1.3 第一個Java應用程序741
A.2 Java基礎744
A.2.1 標識符744
A.2.2 保留字744
A.2.3 變數745
A.2.4 基本類型745
A.2.5 常量746
A.2.6 賦值語句746
A.2.7 賦值兼容性747
A.2.8 類型轉換748
A.2.9 算術運算符和表達式749
A.2.10 括弧和優先規則750
A.2.11 自增和自減運算符751
A.2.12 特殊賦值運算符752
A.2.13 符號常量752
A.2.14 Math類753
A.3 用鍵盤和屏幕進行簡單的輸入和
輸出754
A.3.1 屏幕輸出754
A.3.2 用Scanner類進行鍵盤
輸入755
A.4 if-else語句757
A.4.1 布爾表達式758
A.4.2 嵌套語句761
A.4.3 多重if-else語句763
A.4.4 條件運算符(可選)764
A.5 switch語句764
A.6 枚舉766
A.7 作用域768
A.8 循環769
A.8.1 while語句769
A.8.2 for語句770
A.8.3 do-while語句772
A.8.4 關於循環的其他信息773
A.9 String類774
A.9.1 字元串中的字元775
A.9.2 字元串的聯接776
A.9.3 String方法777
A.10 StringBuilder類779
A.11 使用Scanner抽取字元串的
一部分780
A.12 數組783
A.12.1 數組形參和返回值785
A.12.2 初始化數組786
A.12.3 數組索引出界786
A.12.4 對數組使用=與==786
A.12.5 數組與for-each循環788
A.12.6 多維數組788
A.12 封裝類790
附錄B 異常處理796
B.1 基本的異常處理796
B.2 Java類庫的異常類799
B.3 定義自己的異常類800
B.4 複合catch代碼塊802
B.5 finally代碼塊803
B.6 拋出但不捕獲異常的方法804
B.7 不需要捕獲的異常805
附錄C 文件輸入與輸出807
C.1 概述807
C.1.1 數據流807
C.1.2 文件的優點807
C.1.3 文件的類型808
C.1.4 文件名809
C.1.5 包java.io809
C.2 使用PrintWriter寫文本文件809
C.3 讀取文本文件812
C.3.1 使用Scanner讀取文本文件812
C.3.2 使用BufferedReader讀取
文本文件814
C.3.3 定義打開數據流的方法816
C.4 二進位文件的I/O817
C.4.1 使用DataOutputStream寫
二進位文件817
C.4.2 使用DataInputStream讀取
二進位文件821
C.5 File類823
C.6 對象串列化824
附錄D 文檔與程序設計風格828
D.1 命名變數與類828
D.2 縮排828
D.3 註釋829
D.3.1 單行註釋829
D.3.2 註釋塊830
D.3.3 何時寫註釋830
D.3.4 Java文檔註釋830
D.3.5 運行javadoc832
附錄E 自測題答案833
第1章 Java類
第2章 從已有類創建新類
第3章 類的設計
第4章 線性表
第5章 用數組實現線性表
第6章 用鏈表實現線性表
第7章 完成線性表的鏈表實現
第8章 迭代器
第9章 演演算法的效率
第10章 遞歸
第11章 排序入門
第12章 快速排序演演算法
第13章 有序表
第14章 繼承與線性表
第15章 可變對象、不可變對象與可克隆對象
第16章 查找
第17章 詞典
第18章 詞典的實現
第19章 散列概述
第20章 用散列實現詞典
第21章 棧
第22章 棧的實現
第23章 隊列、雙端隊列與優先隊列
第24章 隊列、雙端隊列與優先隊列的實現
第25章 樹
第26章 樹的實現
第27章 二叉查找樹的實現
第28章 堆的實現
第29章 平衡查找樹
第30章 圖
第31章 圖的實現