0920~0926_夏季暢銷第三波BN

遞迴演算法大師親授面試心法:Python 與 JavaScript 解題全攻略

The Recursive Book of Recursion
  • 9 612
    680

活動訊息

想找書的時候,特別想偷看網友的書櫃... 原來大家都在看這本 ↓↓↓

用閱讀開啟視野,讓書成為照亮你人生的光
【金石堂選書】本月推薦您這些好書👉 快來看看

內容簡介

「無論你想在程式設計面試中獲得優勢,
想創造美麗的數學藝術,
還是頑固地非得理解這個概念的有趣特性,
這本書都將成為你深入遞迴這個兔子洞的指南(兔子洞裡還有兔子洞)。」


遞迴程式設計技術可以產生優雅的程式解決方案,然而更常見的是,它讓程式設計師感到困惑。這並不代表程式設計師可以(或應該)忽略遞迴;儘管遞迴以具有挑戰性而聞名,但它是一個重要的電腦科學主題,並且可以對程式設計本身產生敏銳的洞察力。至少,了解遞迴可以幫助你順利通過程式設計工作面試。

如果你是對電腦科學感興趣的學生,遞迴是你要理解許多流行演算法所必須克服的必要障礙。如果你是程式設計訓練營的畢業生或自學而成的程式設計師,並且順利跳過了更具理論性的電腦科學主題,但在「白板程式設計面試」中肯定還是會遇到遞迴問題。如果你是一位經驗豐富的軟體工程師,以前從未接觸過遞迴演算法,你可能會發現遞迴是你知識中一塊尷尬的缺口。

本書目標讀者
本書適合那些對遞迴演算法感到恐懼或感興趣的人。對於新手程式設計師或電腦科學系的大一新生來說,遞迴主題就像難以理解的黑魔法一樣。大多數遞迴課程都很難理解,使得這個主題不但讓人覺得挫敗,甚至令人心生恐懼。對於這些讀者來說,這本書的直接解釋和充足的例子應該能幫助他們最終理解這個主題。

閱讀本書的唯一先決條件是具備 Python 或 JavaScript 程式語言的基本程式設計經驗,因為各章的程式碼範例使用了這兩種語言。本書的程式已被精簡到核心的基本結構; 如果你知道如何呼叫和建立函數,以及理解全域變數和局部變數之間的區別,那麼你就足以應付這些程式設計範例了。

本書使用 Python 和 JavaScript 範例來教授遞迴的基礎知識,揭示了遞迴的教學方法,並闡明了所有遞迴演算法的基本原理。你將學習何時使用遞迴函數(最重要的是,何時不使用它們),如何實現工作面試中經常提到的經典遞迴演算法,以及遞迴技術如何幫助解決有關樹走訪、組合學等等許許多多的問題,以及其他棘手的話題。

這個以專案為主的指南包含了完整的、可運行的程式,將能幫助你學習:
☑︎ 遞迴函數如何使用呼叫堆疊,這是一種在遞迴課程中幾乎從未討論過的關鍵資料結構
☑︎ 「頭尾」與「信仰飛躍」技巧如何簡化遞迴函數的編寫
☑︎ 如何使用遞迴為你的檔案系統編寫自訂搜尋腳本、繪製碎形藝術、生成迷宮等
☑︎ 優化和記憶如何使遞迴演算法更有效率

 

作者

Al Sweigart

Al Sweigart 是軟體開發人員、Python 軟體基金會院士,也是 No Starch Press 出版多本程式設計書籍的作者,其中包括全球暢銷書《Automate the Boring Stuff with Python》。他所授權的作品《Creative Commons》可在 https://www.inventwithpython.com上找到。

 

目錄

【第一部分:理解遞迴】

Chapter 1 遞迴是什麼?

遞迴的定義
什麼是函數?
什麼是堆疊?
什麼是呼叫堆疊?
什麼是遞迴函數和堆疊溢出?
基本情況和遞迴情況
遞迴呼叫前後的程式碼
結論
延伸閱讀
練習題

Chapter 2 遞迴與迭代
計算階乘
計算費波那契數列
將遞迴演算法轉換為迭代演算法
將迭代演算法轉換為遞迴演算法
案例分析:計算指數
什麼時候需要使用遞迴?
提出遞迴演算法
結論
延伸閱讀
練習題
練習專案

Chapter 3 經典遞迴演算法
對陣列中的數字求和
反轉字串
檢測回文
解決河內塔問題
使用 Flood Fill
使用 Ackermann 函數
結論
延伸閱讀
練習題
練習專案

Chapter 4 回溯和樹走訪演算法
使用樹走訪
在樹中找尋八個字母的名字
取得樹的最大深度
解決迷宮問題
結論
延伸閱讀
練習題
練習專案

Chapter 5 各個擊破演算法
二元搜尋:在按照字母順序排列的書架中尋找一本書
快速排序:將未排序的書堆拆分為已排序的書堆
合併排序:將小堆撲克牌合併成較大的排序堆
對整數陣列求和
Karatsuba 乘法
Karatsuba 演算法背後的代數
結論
延伸閱讀
練習題
練習專案

Chapter 6 排列組合
集合論的術語
找到所有不重複的排列:婚禮座位表
使用巢狀迴圈來取得排列:一種不太理想的方法
重複排列:密碼破解
透過遞迴取得 K 組合
取得平衡括號的所有組合
冪集:找出集合的所有子集合
結論
延伸閱讀
練習題
練習專案

Chapter 7 記憶化與動態規劃
記憶化
Python 的 functools 模組
當你記憶化非純函數時會發生什麼事?
結論
延伸閱讀
練習題

Chapter 8 尾部呼叫優化
尾部遞迴和尾部呼叫優化如何運作
尾部遞迴中的累加器
尾部遞迴的局限性
尾部遞迴的案例研究
結論
延伸閱讀
練習題

Chapter 9 繪製碎形
烏龜圖形
基本的烏龜函數
Sierpinski 三角形
Sierpinski 地毯
碎形樹
英國的海岸有多長?Koch 曲線和雪花
Hilbert 曲線
結論
延伸閱讀
練習題
練習專案

【第二部分:專案】

Chapter 10 檔案搜尋器

完整的檔案搜尋程式
配對函數
遞迴 walk() 函數
呼叫 walk() 函數
用於處理檔案的有用 Python 標準函式庫函數
結論
延伸閱讀

Chapter 11 迷宮生成器
完整的迷宮生成器程式
設定迷宮生成器的常數
建立迷宮資料結構
印出迷宮資料結構
使用遞迴回溯演算法
啟動遞迴呼叫鏈
結論
延伸閱讀

Chapter 12 滑塊解題器
遞迴解決 15-puzzle
完整的滑塊解題器程式
設定程式的常數
將滑塊拼圖表示為資料
設定新拼圖
遞迴解決滑塊拼圖問題
啟動解題器
結論
延伸閱讀

Chapter 13 Fractal Art Maker
內建碎形
Fractal Art Maker 演算法
完整的 Fractal Art Maker 程式
設定常數和 Turtle 的配置
使用「形狀繪製」函數
使用碎形繪圖函數
建立碎形範例
建立你自己的碎形
結論
延伸閱讀

Chapter 14 畫中畫創作家
安裝 Python 的 Pillow 函式庫
描繪你的圖像
完整的 Droste Maker 程式
配置
尋找洋紅色區域
調整基本圖像的大小
遞迴地將圖像放置在圖像內
結論
延伸閱讀

配送方式

  • 台灣
    • 國內宅配:本島、離島
    • 到店取貨:
      金石堂門市 不限金額免運費
      7-11便利商店 ok便利商店 萊爾富便利商店 全家便利商店
  • 海外
    • 國際快遞:全球
    • 港澳店取:
      ok便利商店 順豐 7-11便利商店

詳細資料

詳細資料

    • 語言
    • 中文繁體
    • 裝訂
    • 紙本平裝
    • ISBN
    • 9786263338951
    • 分級
    • 普通級
    • 頁數
    • 384
    • 商品規格
    • 23*17*2
    • 出版地
    • 台灣
    • 適讀年齡
    • 全齡適讀
    • 注音
    • 級別

商品評價

訂購/退換貨須知

加入金石堂 LINE 官方帳號『完成綁定』,隨時掌握出貨動態:

加入金石堂LINE官方帳號『完成綁定』,隨時掌握出貨動態
金石堂LINE官方帳號綁定教學

提醒您!!
金石堂及銀行均不會請您操作ATM! 如接獲電話要求您前往ATM提款機,請不要聽從指示,以免受騙上當!

退換貨須知:

**提醒您,鑑賞期不等於試用期,退回商品須為全新狀態**

  • 依據「消費者保護法」第19條及行政院消費者保護處公告之「通訊交易解除權合理例外情事適用準則」,以下商品購買後,除商品本身有瑕疵外,將不提供7天的猶豫期:
    1. 易於腐敗、保存期限較短或解約時即將逾期。(如:生鮮食品)
    2. 依消費者要求所為之客製化給付。(客製化商品)
    3. 報紙、期刊或雜誌。(含MOOK、外文雜誌)
    4. 經消費者拆封之影音商品或電腦軟體。
    5. 非以有形媒介提供之數位內容或一經提供即為完成之線上服務,經消費者事先同意始提供。(如:電子書、電子雜誌、下載版軟體、虛擬商品…等)
    6. 已拆封之個人衛生用品。(如:內衣褲、刮鬍刀、除毛刀…等)
  • 若非上列種類商品,均享有到貨7天的猶豫期(含例假日)。
  • 辦理退換貨時,商品(組合商品恕無法接受單獨退貨)必須是您收到商品時的原始狀態(包含商品本體、配件、贈品、保證書、所有附隨資料文件及原廠內外包裝…等),請勿直接使用原廠包裝寄送,或於原廠包裝上黏貼紙張或書寫文字。
  • 退回商品若無法回復原狀,將請您負擔回復原狀所需費用,嚴重時將影響您的退貨權益。
※ 網友掛保證,絕不踩雷書單如下 ↓↓↓
預計 2025/10/01 出貨 購買後進貨 
金石堂門市 全家便利商店 ok便利商店 萊爾富便利商店 7-11便利商店
World wide
活動ing