」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 遞迴-1

遞迴-1

發佈於2024-11-08
瀏覽:349

簡介1

函數呼叫自身的過程稱為遞歸,
對應的函數稱為遞歸函數.
由於電腦程式設計是數學的基本應用,因此讓
我們首先嘗試理解遞歸背後的數學推理。
一般來說,我們都知道函數的概念。簡而言之,函數是
提供輸入時產生輸出的數學方程式。例如:
假設函數 F(x) 是由下式定義的函數: F(x) = x^2 4
我們可以將此函數的 Java 程式碼編寫為:

公共靜態 int F(int x){
返回 (x * x 4);
}

現在,我們可以將 x 的不同值傳遞給該函數並接收我們的輸出
因此。
在繼續遞歸之前,讓我們試著理解另一個數學
稱為 數學歸納原理 (PMI) 的概念

數學歸納原理 (PMI) 是一種證明陳述的技術,a
公式,或關於一組自然數的定理。它有
以下三步:
1.** 簡單案例的步驟*:在這一步驟中,我們將證明
所需的陳述 基本情況,例如 n = 0 或 n = 1。
2.
* 假設步驟**:在這一步驟中,我們將假設所需的語句
對於 n = k 有效。

  1. 證明步驟:根據假設步驟的結果,我們將證明, 只要 n = k 為真,n = k 1 對於所需方程式也成立。

例如:讓我們用數學歸納法證明:
S(N): 1 2 3 ... N = (N * (N 1))/2
(前N個自然數和)
證明:
步驟 1:當 N = 1 時,S(1) = 1 成立。
步驟 2:假設,對於 N = k,給定的陳述成立,即
1 2 3 .... k = (k * (k 1))/2
步驟 3:讓我們使用步驟 2 來證明 N = k 1 的陳述。

證明: 1 2 3 ... (k 1) = ((k 1)*(k 2))/2
證明:

將(k 1)加入步驟2所獲得的結果中的LHS與RHS:
1 2 3 ... (k 1) = (k*(k 1))/2 (k 1)

現在,從 RHS 端取 (k 1) common:
1 2 3 ... (k 1) = (k 1)*((k 2)/2)

根據我們試圖證明的說法:
1 2 3 ... (k 1) = ((k 1)*(k 2))/2
由此證明。

遞歸的工作

總結以上三點我們就可以定義遞歸方法的步驟了
步驟:
●基本情況:遞迴函數必須有一個終止條件,其中
該進程將停止呼叫自身。這種情況稱為基本情況。如果沒有基本情況,它將不斷調用自身並陷入
無限循環。很快,就會超出遞歸深度*,並且會拋出
錯誤。
●遞歸呼叫:遞歸函數將在較小的版本上呼叫自身
的主要問題。我們在編寫此步驟時需要小心
正確找出你的小問題是什麼至關重要。
●小計算:一般我們在每個遞歸
中執行一次計算步驟 稱呼。我們可以在遞歸呼叫之前或之後實現這個​​計算步驟
取決於問題的性質。

注意:遞歸使用儲存遞歸呼叫的內建堆疊。因此,
遞歸呼叫的次數必須盡可能少,以避免記憶體溢位。如果
遞歸呼叫次數超過最大允許數量,
**將超過遞歸深度
**。
現在,讓我們看看如何使用遞歸解決一些常見問題

問題陳述 - 求一個數的階乘

方法:找出 PMI 的三個步驟,然後使用
將其關聯起來 遞迴

  1. 歸納步驟:計算數字 n - F(n) 的階乘 歸納假設:我們已經得到了n-1 - F(n-1)
  2. 的階乘
  3. 用F(n-1)表示F(n):F(n)=n*F(n-1)。因此我們得到

public static int fact(int n){
int ans = 事實(n-1); #假設步驟
返回 ans * n; #從假設步驟解決問題
}

  1. 代碼仍然不完整。缺少的部分是基本情況。現在我們將 試運轉以查找需要停止遞歸的情況。考慮 n = 5:

Recursion -1

正如我們上面所看到的,我們已經知道n = 0的答案,即1。所以我們將
將此作為我們的基本情況。因此,程式碼現在變成:

公共靜態 int 階乘(int n){
if (n == 0) // 基本情況
返回 1;
別的
傳回 n*階乘(n-1); // 遞迴情況
}

版本聲明 本文轉載於:https://dev.to/vishnub33527201/recursion-1-3p1e?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • 插入資料時如何修復「常規錯誤:2006 MySQL 伺服器已消失」?
    插入資料時如何修復「常規錯誤:2006 MySQL 伺服器已消失」?
    插入記錄時如何解決「一般錯誤:2006 MySQL 伺服器已消失」介紹:將資料插入MySQL 資料庫有時會導致錯誤「一般錯誤:2006 MySQL 伺服器已消失」。當與伺服器的連線遺失時會出現此錯誤,通常是由於 MySQL 配置中的兩個變數之一所致。 解決方案:解決此錯誤的關鍵是調整wait_tim...
    程式設計 發佈於2024-12-22
  • 如何將 Base64 字串轉換為 PNG 映像並儲存到檔案?
    如何將 Base64 字串轉換為 PNG 映像並儲存到檔案?
    將Base64 中的字串轉換為映像並保存在檔案系統上問題:我有一個字串base64 格式,表示PNG 圖片。有沒有辦法將此圖像作為 PNG 檔案保存到檔案系統? 答案:import base64 # Decode the base64 string into bytes image_data = b...
    程式設計 發佈於2024-12-22
  • Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta:列偏移的刪除和恢復Bootstrap 4 在其Beta 1 版本中引入了重大更改柱子偏移了。然而,隨著 Beta 2 的後續發布,這些變化已經逆轉。 從 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    程式設計 發佈於2024-12-22
  • 為什麼我的 VB.Net Telegram API AuthKey Exchange 無法產生有效的 AuthKey?
    為什麼我的 VB.Net Telegram API AuthKey Exchange 無法產生有效的 AuthKey?
    首先,我還沒有完成身份驗證-授權金鑰交換。我已經很接近了,但目前我得到的結果包含無效值(例如 AuthKey 包含多種類型的未知值,而我預計大部分為 0)。 儘管此 VB.Net 腳本與 Telegram API 的 AuthKey 序列非常相似,但它無法完成並產生有效的 AuthKey。其他發現的...
    程式設計 發佈於2024-12-22
  • 為什麼密碼中的美元符號 ($) 會導致資料庫連線問題?
    為什麼密碼中的美元符號 ($) 會導致資料庫連線問題?
    美元($) 登入密碼字串導致資料庫連線問題在最近遇到的情況中,PHP 應用程式在建立與MySQL 資料庫的連線時遇到了困難。儘管使用了正確的憑證,資料庫仍然無法存取。 調查顯示密碼包含美元($) 符號:$_DB["password"] = "mypas$word&quo...
    程式設計 發佈於2024-12-22
  • 如何使用 JavaScript 動態更改 CSS :root 顏色變數?
    如何使用 JavaScript 動態更改 CSS :root 顏色變數?
    更改CSS :JavaScript 中的根顏色變數在Web 開發領域,自訂網頁的視覺變數通常是透過CSS 的使用。這些變數在 CSS 的 :root 部分中定義,使開發人員能夠控制設計的各個方面。常見的場景是能夠使用 JavaScript 動態變更這些顏色。 要實現這一點,關鍵程式碼是:docume...
    程式設計 發佈於2024-12-22
  • 在 Go 中使用 WebSocket 進行即時通信
    在 Go 中使用 WebSocket 進行即時通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要一种比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSoc...
    程式設計 發佈於2024-12-22
  • ES6 區塊級函數語意在嚴格模式和非嚴格模式下有何不同,以及 Web 擴充如何影響它們?
    ES6 區塊級函數語意在嚴格模式和非嚴格模式下有何不同,以及 Web 擴充如何影響它們?
    理解ES6 區塊級函數的語意簡介隨著ES6 的出現,區塊級函數聲明成為該語言的一個有價值的補充。儘管有最初的假設,這些函數的精確語義涵蓋了更廣泛的範圍,包括嚴格模式和非嚴格模式之間的區別以及瀏覽器相容性考慮因素。 語意下表總結了區塊級函數語意的關鍵面向:執行環境 ]外部可見塊提升至塊頂部TDZ非嚴格...
    程式設計 發佈於2024-12-22
  • Go 條件編譯中 `//go:build` 和 `// +build` 之間的主要差異是什麼?
    Go 條件編譯中 `//go:build` 和 `// +build` 之間的主要差異是什麼?
    //go:build 和// build 之間的區別在Go 1.17 中,引入了一個名為//go:build 的新條件編譯指令來取代舊的// 建構指令。雖然這兩個指令都具有指定構建約束的相同目的,但使用//go:build.語法差異://go:build 有幾個關鍵區別和優點遵循與其他Go 指令類...
    程式設計 發佈於2024-12-22
  • HTML 格式標籤
    HTML 格式標籤
    HTML 格式化元素 **HTML Formatting is a process of formatting text for better look and feel. HTML provides us ability to format text without us...
    程式設計 發佈於2024-12-22
  • C 中「void」的大小是多少?
    C 中「void」的大小是多少?
    問題:理解「void」的未定義大小在 C 程式設計中,關鍵字「void」表示類型的缺失。這就提出了一個問題:「void」的大小是多少? 答案:型「void」在 C 中沒有定義大小。它不是一個物件或指標的有效類型,因此嘗試這樣使用它會導致編譯錯誤。具體來說,語句:void n;是無效的,因為它試圖聲明...
    程式設計 發佈於2024-12-22
  • 為什麼Python這種解釋性語言會產生.pyc檔?
    為什麼Python這種解釋性語言會產生.pyc檔?
    如果Python是解釋型語言,為什麼會存在.pyc檔? 雖然Python通常被稱為解釋型語言,但它並不是嚴格準確。解釋只是其實現的一個層次。 從語言角度看將Python定義為解釋語言是指其底層語言規範,與具體實現不同。 Python 如何解釋原始碼的實作細節可能會根據所使用的特定 Python 解釋...
    程式設計 發佈於2024-12-22
  • 在有 Echo 和 Return 的 PHP 連線中何時使用逗號與句點?
    在有 Echo 和 Return 的 PHP 連線中何時使用逗號與句點?
    標點符號在PHP 連接中的重要性:句點和逗號與回顯和回車的研究在PHP 中,連接起著至關重要的作用在字串操作中。但是,在與 echo 和 return 等不同結構連接時選擇使用句點或逗號可能會導致意外結果。讓我們探討一下這種差異的複雜性。 理解 Echo 和 ReturnEcho 是為輸出資料而設計...
    程式設計 發佈於2024-12-22
  • 如何在 PHP 中追加數組而不進行基於鍵的複製?
    如何在 PHP 中追加數組而不進行基於鍵的複製?
    優雅地追加數組,無需基於鍵的重複在PHP 數組操作領域,將一個數組追加到另一個數組而不覆蓋其鍵可以提出挑戰。許多開發人員求助於使用 array_push 或陣列聯合運算子 ( ) 等方法,這通常會產生不期望的結果。 但是,有一個優雅的解決方案,可以無縫合併數組,同時保留其金鑰完整性。輸入數字組合併。...
    程式設計 發佈於2024-12-22
  • C++ 程式支援可變長度數組 (VLA) 嗎?
    C++ 程式支援可變長度數組 (VLA) 嗎?
    C 中的可變長度數組:揭穿的神話C 中的可變長度數組(VLA) 的前景一直是爭論的主題多年來。雖然 VLA 已成為 C99 標準的組成部分,但它們在 C 中的存在仍然是一個問號。 C99 規範明確允許聲明可變長度數組,其中數組的大小未在編譯時而是在執行期間動態確定。然而,C 對 VLA 的立場卻不那...
    程式設計 發佈於2024-12-22

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3