遞歸程式在C++中找到陣列的最小和最大元素
我們以整數陣列Arr[]作為輸入。目標是使用遞歸方法在陣列中找到最大和最小的元素。
由於我們使用遞歸,我們將遍歷整個數組,直到達到長度=1,然後返回A[0],這形成了基本情況。否則,將當前元素與當前最小或最大值進行比較,並透過遞歸更新其值以供後續元素使用。
讓我們看看這個的各種輸入輸出場景−
輸入 #− Arr= {12,67,99,76,32};
輸出 − 陣列中的最大值:99
解釋 − 在所有元素中,99是其中的最大值。
輸入 − Arr= {1,0,-99,9,3};
輸出 − 陣列中的最小值:- 99
解釋 − 在所有元素中,-99是其中的最小值。
下面程式中使用的方法如下
找出最小值
#以陣列Arr[]作為輸入。
函數recforMin(int arr[], int len)接受輸入數組和其長度,並使用遞歸返回數組中的最小值。
取整數變數minimum
如果目前索引len為1,則設定minimum=arr[0]並傳回minimum。
否則設定minimum = arr[len]或recforMin(arr,len-1)的最小值,並傳回它。
最後將傳回最小元素。
在main函數中印出得到的結果。
找出最大值
以陣列Arr[]作為輸入。
函數recforMax(int arr[], int len)接受輸入陣列和長度,並使用遞迴傳回陣列中的最大值。
取整數變數maximum。
如果目前索引len為1,則設定maximum=arr[0]並傳回maximum。
否則設定maximum = arr[len]或recforMax(arr,len-1)的最大值,並傳回它。
最後將傳回最大元素。
在main函數中印出得到的結果。
使用遞迴尋找最小值
#範例
#include <iostream> using namespace std; int recforMin(int arr[], int len){ int minimum; if (len == 1){ minimum=arr[0]; return minimum; } else{ return minimum=arr[len]<recforMin(arr,len-1)?arr[len]:recforMin(arr,len-1); } } int main(){ int Arr[] = {-89,98,76,32,21,35,100}; int length = sizeof(Arr)/sizeof(Arr[0]); cout <<"Minimum in the array :"<<recforMin(Arr, length); return 0; }
輸出
如果我們執行上述程式碼,將會產生以下輸出
Minimum in the array :-89
使用遞迴求最小值
範例
#include <iostream> using namespace std; int recforMax(int arr[], int len){ int maximum; if (len == 1){ maximum=arr[0]; return maximum; } else{ return maximum=arr[len]>recforMax(arr,len-1)?arr[len]:recforMax(arr,len-1); } } int main(){ int Arr[] = {-89,98,76,32,21,35,100}; int length = sizeof(Arr)/sizeof(Arr[0]); cout <<"Maximum in the array :"<<recforMax(Arr, length); return 0; }
輸出
如果我們執行上述程式碼,將會產生以下輸出
Maximum in the array :-100
以上是遞歸程式在C++中找到陣列的最小和最大元素的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

PHP數組鍵值翻轉方法效能比較顯示:array_flip()函數在大型數組(超過100萬個元素)下比for迴圈效能更優,耗時更短。手動翻轉鍵值的for迴圈方法耗時相對較長。

遞歸是一種強大的技術,它允許函數呼叫自身來解決問題,在C++中,遞歸函數由兩個關鍵要素構成:基本情況(確定遞歸何時停止)和遞歸呼叫(將問題分解為更小子問題)。透過理解基礎知識並練習實戰範例(如階乘計算、斐波那契數列和二元樹遍歷),您可以建立遞歸直覺,並自信地在程式碼中使用它。

PHP的array_group_by函數可依鍵或閉包函數將陣列中的元素分組,傳回關聯數組,其中鍵為組名,值是屬於該組的元素數組。

遞歸是一種函數呼叫自身的技術,但存在著堆疊溢位和效率低下的缺點。替代方法包括:尾遞歸最佳化,由編譯器最佳化遞歸呼叫為循環;迭代,使用循環而不是遞歸;協程,允許暫停和恢復執行,模擬遞歸行為。

遞歸定義及最佳化:遞歸:函數內部呼叫自身,解決可分解為更小子問題的難題。尾遞歸:函數進行所有計算後才進行遞歸調用,可最佳化為循環。尾遞歸最佳化條件:遞歸呼叫為最後操作。遞歸呼叫參數與原始呼叫參數相同。實戰範例:計算階乘:輔助函數factorial_helper實現尾遞歸最佳化,消除呼叫棧,提高效率。計算斐波那契數列:尾遞歸函數fibonacci_helper利用最佳化,高效率計算斐波那契數。

PHP的array_group()函數可用來按指定鍵對陣列進行分組,以尋找重複元素。函數透過以下步驟運作:使用key_callback指定分組鍵。可選地使用value_callback確定分組值。對分組元素進行計數並識別重複項。因此,array_group()函數對於尋找和處理重複元素非常有用。

是的,在許多程式語言中,數組可以作為函數參數,函數將對其中儲存的資料執行操作。例如C++中的printArray函數可以列印數組中的元素,而Python中的printArray函數可以遍歷數組並列印其元素。這些函數對陣列所做的修改也會反映在呼叫函數中的原始數組中。
