算法基礎:Python和C#語言實現(xiàn)(原書第2版)
定 價:119 元
- 作者:羅德·斯蒂芬斯(Rod Stephens)
- 出版時間:2021/1/1
- ISBN:9787111671855
- 出 版 社:機械工業(yè)出版社
- 中圖法分類:TP301.6
- 頁碼:424
- 紙張:
- 版次:
- 開本:16開
本書第2版進行了全面修訂與更新,更加易于學習。書中描述了那些重要且經(jīng)典的算法,并且說明了不同算法的適用情境。跟隨作者的講解,讀者將學會分析既有算法,進而理解算法背后的原理。同時,讀者也將學習創(chuàng)建新的算法,以適應未來的新需求。這些有用的算法包括:操作常用數(shù)據(jù)結構的方法,高級數(shù)據(jù)結構,網(wǎng)絡算法,以及數(shù)值算法。此外,書中還包含通用的問題求解技巧。除了描述算法,作者還詳細介紹了如何分析算法的性能。書中提供大量練習,讀者可以自己探索修改算法的方法,以便將其應用于新的情境。
出版者的話
譯者序
前言
作者簡介
第1章 算法基礎 1
1.1 方法 1
1.2 算法和數(shù)據(jù)結構 2
1.3 偽代碼 2
1.4 算法的特點 4
1.4.1 大O符號 5
1.4.2 常用的運行時間函數(shù) 7
1.4.3 運行時間函數(shù)的可視化比較 11
1.5 實際考慮 12
1.6 本章小結 13
1.7 練習題 14
第2章 數(shù)值算法 16
2.1 數(shù)據(jù)隨機化 16
2.1.1 隨機數(shù)生成器 16
2.1.2 隨機化數(shù)組 20
2.1.3 生成非均勻分布 21
2.1.4 隨機行走 22
2.2 查找最大公約數(shù) 25
2.2.1 計算最大公約數(shù) 25
2.2.2 最大公約數(shù)算法的擴展應用 27
2.3 計算乘冪 28
2.4 處理素數(shù) 29
2.4.1 查找素數(shù)因子 29
2.4.2 查找素數(shù) 31
2.4.3 素性檢驗 32
2.5 計算數(shù)值積分 33
2.5.1 矩形法則 34
2.5.2 梯形法則 34
2.5.3 自適應積分算法 35
2.5.4 蒙特卡羅積分法 37
2.6 方程求解 38
2.7 高斯消元法 40
2.7.1 前向消元 40
2.7.2 后向代換 41
2.7.3 算法實現(xiàn) 42
2.8 最小二乘法擬合 42
2.8.1 線性最小二乘法 43
2.8.2 多項式最小二乘法 44
2.9 本章小結 45
2.10 練習題 46
第3章 鏈表 48
3.1 基本概念 48
3.2 單向鏈表 49
3.2.1 遍歷鏈表 49
3.2.2 查找節(jié)點 49
3.2.3 使用哨兵 50
3.2.4 在頂部添加節(jié)點 51
3.2.5 在尾部添加節(jié)點 51
3.2.6 在指定節(jié)點后插入節(jié)點 52
3.2.7 刪除節(jié)點 52
3.3 雙向鏈表 53
3.4 有序鏈表 54
3.5 自組織鏈表 55
3.5.1 前移方法 56
3.5.2 交換方法 56
3.5.3 計數(shù)方法 56
3.5.4 混合方法 56
3.5.5 偽代碼 57
3.6 鏈表算法 57
3.6.1 復制鏈表 58
3.6.2 插入排序 58
3.6.3 選擇排序 60
3.7 多線鏈表 61
3.8 循環(huán)鏈表 61
3.8.1 標記節(jié)點 62
3.8.2 使用哈希表 63
3.8.3 鏈表回溯 64
3.8.4 鏈表反轉 65
3.8.5 龜兔賽跑算法 66
3.8.6 雙向鏈表中的環(huán)路 68
3.9 本章小結 68
3.10 練習題 68
第4章 數(shù)組 70
4.1 基本概念 70
4.2 一維數(shù)組 72
4.2.1 查找數(shù)組元素 72
4.2.2 查找最大值、最小值和平均值 72
4.2.3 查找中值 73
4.2.4 查找眾數(shù) 74
4.2.5 插入數(shù)組元素 76
4.2.6 刪除數(shù)組元素 77
4.3 非零數(shù)組下界 77
4.3.1 二維數(shù)組 78
4.3.2 高維數(shù)組 78
4.4 三角形數(shù)組 81
4.5 稀疏數(shù)組 83
4.5.1 查找行或列 84
4.5.2 獲取元素的值 85
4.5.3 設置元素的值 86
4.5.4 刪除數(shù)組元素 87
4.6 矩陣 89
4.7 本章小結 91
4.8 練習題 91
第5章 堆棧和隊列 93
5.1 堆棧 93
5.1.1 鏈表堆棧 94
5.1.2 數(shù)組堆棧 95
5.1.3 雙堆棧 96
5.1.4 堆棧算法 97
5.2 隊列 101
5.2.1 鏈表隊列 101
5.2.2 數(shù)組隊列 102
5.2.3 特殊隊列 104
5.3 二項堆 105
5.3.1 二項樹的定義 105
5.3.2 二項堆的定義 106
5.3.3 合并樹 107
5.3.4 合并堆 108
5.3.5 入隊操作 111
5.3.6 出隊操作 111
5.3.7 運行時間分析 112
5.4 本章小結 113
5.5 練習題 113
第6章 排序 115
6.1 O(N 2)算法 115
6.1.1 數(shù)組的插入排序算法 115
6.1.2 數(shù)組的選擇排序算法 116
6.1.3 冒泡排序算法 117
6.2 O(NlogN)算法 119
6.2.1 堆排序算法 120
6.2.2 快速排序算法 124
6.2.3 合并排序算法 130
6.3 小于O(NlogN)的算法 132
6.3.1 計數(shù)排序算法 132
6.3.2 鴿巢排序算法 133
6.3.3 桶排序算法 135
6.4 本章小結 136
6.5 練習題 137
第7章 查找 139
7.1 線性查找算法 139
7.2 二分查找算法 140
7.3 插值查找算法 141
7.4 多數(shù)投票算法 142
7.5 本章小結 143
7.6 練習題 144
第8章 哈希表 145
8.1 哈希表的基本概念 145
8.2 鏈接哈希表 146
8.3 開放尋址哈希表 147
8.3.1 刪除數(shù)據(jù)項 148
8.3.2 線性探測 149
8.3.3 二次探測 150
8.3.4 偽隨機探測 151
8.3.5 雙重哈希 151
8.3.6 有序哈希 152
8.4 本章小結 154
8.5 練習題 154
第9章 遞歸 156
9.1 基本算法 156
9.1.1 階乘 156
9.1.2 斐波那契數(shù) 158
9.1.3 棒料切割問題 159
9.1.4 漢諾塔 161
9.2 圖形算法 163
9.2.1 科赫曲線 163
9.2.2 希爾伯特曲線 165
9.2.3 謝爾賓斯基曲線 166
9.2.4 墊圈圖案 168
9.2.5 天際線問題 168
9.3 回溯算法 172
9.3.1 八皇后問題 173
9.3.2 騎士巡游問題 175
9.4 組合與排列 177
9.4.1 基于循環(huán)的組合 178
9.4.2 允許重復項的組合 179
9.4.3 不允許重復項的組合 180
9.4.4 允許重復項的排列 181
9.4.5 不允許重復項的排列 182
9.4.6 輪詢調度算法 183
9.5 遞歸的刪除 188
9.5.1 尾部遞歸的刪除 188
9.5.2 動態(tài)規(guī)劃 189
9.5.3 自底向上編程 190
9.5.4 刪除遞歸的通用方法 191
9.6 本章小結 193
9.7 練習題 194
第10章 樹 196
10.1 有關樹的術語 196
10.2 二叉樹的性質 198
10.3 樹的表示 200
10.3.1 構建常規(guī)樹 200
10.3.2 構建完全樹 203
10.4 樹的遍歷 203
10.4.1 前序遍歷 204
10.4.2 中序遍歷 206
10.4.3 后序遍歷 206
10.4.4 廣度優(yōu)先遍歷 207
10.4.5 遍歷的應用 207
10.4.6 遍歷的運行時間分析 208
10.5 有序樹 208
10.5.1 添加節(jié)點 209
10.5.2 查找節(jié)點 210
10.5.3 刪除節(jié)點 211
10.6 最小共同祖先 212
10.6.1 在有序樹中查找最小共同祖先 212
10.6.2 使用指向父節(jié)點的指針 213
10.6.3 使用指向父節(jié)點的指針和深度字段 214
10.6.4 常規(guī)樹 214
10.6.5 歐拉環(huán)游 216
10.6.6 所有節(jié)點對的最小共同祖先 217
10.7 線索樹 217
10.7.1 構建線索樹 218
10.7.2 線索樹的應用 220
10.8 特殊的樹算法 221
10.8.1 動物游戲 221
10.8.2 表達式求值 223
10.9 區(qū)間樹 224
10.9.1 構建區(qū)間樹 225
10.9.2 與點相交 226
10.9.3 與區(qū)間相交 226
10.9.4 四叉樹 228
10.9.5 字符串樹 231
10.10 本章小結 235
10.11 練習題 235
第11章 平衡樹 239
11.1 AVL樹 239
11.1.1 添加值 239
11.1.2 刪除值 240
11.2 2-3樹 241
11.2.1 添加值 242
11.2.2 刪除值 242
11.3 B樹 244
11.3.1 添加值 245
11.3.2 刪除值 245
11.4 平衡樹的變種 246
11.4.1 自頂向下的B樹 246
11.4.2 B+樹 247
11.5 本章小結 248
11.6 練習題 248
第12章 決策樹 250
12.1 搜索博弈樹 250
12.1.1 極小極大算法 251
12.1.2 初始移動和響應 254
12.1.3 博弈樹啟發(fā)式算法 254
12.2 搜索常規(guī)決策樹 255
12.2.1 優(yōu)化問題 256
12.2.2 窮舉搜索 257
12.2.3 分支定界搜索 258
12.2.4 決策樹啟發(fā)式算法 259
12.2.5 其他決策樹問題 264
12.3 群集智能 267
12.3.1 蟻群優(yōu)化算法 268
12.3.2 蜂群算法 268
12.3.3 群集仿真 269
12.4 本章小結 270
12.5 練習題 271
第13章 基本網(wǎng)絡算法 274
13.1 有關網(wǎng)絡的術語 274
13.2 網(wǎng)絡的表示 276
13.3 遍歷 278
13.3.1 深度優(yōu)先遍歷 278
13.3.2 廣度優(yōu)先遍歷 280
13.3.3 連通性測試 281
13.3.4 生成樹 282
13.3.5 最小生成樹 283
13.3.6 歐幾里得最小生成樹 284
13.3.7 構建迷宮 284
13.4 強連通組件 285
13.4.1 Kosaraju算法 285
13.4.2 關于Kosaraju算法的討論 286
13.5 查找路徑 288
13.5.1 查找任意路徑 288
13.5.2 標簽設置最短路徑 289
13.5.3 標簽修正最短路徑 291
13.5.4 所有節(jié)點對的最短路徑 292
13.6 傳遞性 295
13.6.1 傳遞閉包 295
13.6.2 傳遞歸約 296
13.7 最短路徑算法的改進 298
13.7.1 形狀點 298
13.7.2 提前終止 299
13.7.3 雙向搜索 299
13.7.4 最佳優(yōu)先搜索 299
13.7.5 轉彎懲罰和禁行 299
13.8 本章小結 302
13.9 練習題 302
第14章 高級網(wǎng)絡算法 304
14.1 拓撲排序 304
14.2 回路檢測 306
14.3 地圖著色 307
14.3.1 雙色地圖 307
14.3.2 三色地圖 308
14.3.3 四色地圖 309
14.3.4 五色地圖 309
14.3.5 其他地圖著色算法 312
14.4 最大流量 312
14.4.1 工作分配 314
14.4.2 最小流量切割 314
14.5 網(wǎng)絡克隆 316
14.5.1 字典 316
14.5.2 克隆引用 317
14.6 節(jié)點團 318
14.6.1 暴力破解方法 318
14.6.2 Bron-Kerbosch算法 319
14.6.3 查找三角形節(jié)點團 323
14.7 社區(qū)檢測 324
14.7.1 極大節(jié)點團 325
14.7.2 Girvan-Newman算法 325
14.7.3 派系過濾法 326
14.8 歐拉路徑和歐拉回路 326
14.8.1 暴力破解方法 327
14.8.2 弗萊里算法 327
14.8.3 Hierholzer算法 327
14.9 本章小結 328
14.10 練習題 329
第15章 字符串算法 331
15.1 匹配括號 331
15.1.1 算術表達式求值 332
15.1.2 構建解析樹 332
15.2 模式匹配 333
15.2.1 DFA 333
15.2.2 為正則表達式構建DFA 335
15.2.3 NFA 336
15.3 字符串搜索 337
15.4 計算編輯距離 340
15.5 語音算法 342
15.5.1 Soundex 342
15.5.2 Metaphone 343
15.6 本章小結 344
15.7 練習題 344
第16章 密碼學 347
16.1 術語 347
16.2 置換加密算法 348
16.2.1 行/列置換加密算法 348
16.2.2 列置換加密算法 349
16.2.3 路由加密算法 351
16.3 替換加密算法 351
16.3.1 愷撒替換加密算法 351
16.3.2 維吉尼亞加密算法 352
16.3.3 簡單替換加密算法 354
16.3.4 一次性便箋加密器 354
16.4 分組加密算法 355
16.4.1 替換-置換網(wǎng)絡加密算法 355
16.4.2 菲斯特爾加密算法 356
16.5 公開密鑰加密與RSA 357
16.5.1 歐拉函數(shù) 358
16.5.2 乘法逆元 358
16.5.3 RSA示例 358
16.5.4 實際考慮 359
16.6 密碼學的其他應用場景 359
16.7 本章小結 360
16.8 練習題 360
第17章 計算復雜性理論 362
17.1 標記法 362
17.2 算法復雜性類別 363
17.3 歸約 365
17.3.1 3SAT 366
17.3.2 二分圖匹配 366
17.4 NP難問題 367
17.5 檢測問題、報告問題和優(yōu)化問題 367
17.5.1 檢測問題≤p報告問題 368
17.5.2 報告問題≤p優(yōu)化問題 368
17.5.3 報告問題≤p檢測問題 368
17.5.4 優(yōu)化問題≤p報告問題 369
17.5.5 近似優(yōu)化 369
17.6 NP完全問題 369
17.7 本章小結 371
17.8 練習題 372
第18章 分布式算法 374
18.1 并行計算的類型 374
18.1.1 脈動陣列 374
18.1.2 分布式計算 376
18.1.3 多CPU處理 378
18.1.4 競爭條件 378
18.1.5 死鎖 381
18.1.6 量子計算 382
18.2 分布式算法 382
18.2.1 調試分布式算法 383
18.2.2 密集并行算法 383
18.2.3 合并排序算法 384
18.2.4 哲學家就餐問題 385
18.2.5 兩個將軍問題 387
18.2.6 拜占庭將軍問題 388
18.2.7 一致性問題 390
18.2.8 領導選舉 393
18.2.9 快照技術 393
18.2.10 時鐘同步 394
18.3 本章小結 395
18.4 練習題 395
第19章 面試難題 397
19.1 面試官提出面試難題 398
19.2 應聘者回答面試難題 399
19.3 本章小結 402
19.4 練習題 403
附錄 練習題參考答案