遞歸插入排序的C程序
插入排序是一種排序演算法,它是一種基於就地比較的演算法。
此演算法的工作原理是將元素放置在已排序子數組中的位置,即元素之前的子數組是排序子數組。
演算法
Step1 - 從 1 到 n-1 迴圈並執行 -
Step2 .1 - 選擇位置 i 處的元素,array[i]。
Step2.2 - 將元素插入已排序的子數組 array[0] 中其位置到 arr[i]。
我們透過一個例子來理解演算法
陣列 = [34, 7, 12, 90, 51]
對於i = 1,arr[1] = 7,放入子數組arr[0] - arr[1] 中的位置。
[7, 34, 12, 90, 51]
對於 i = 2,arr[2] = 12,放入子陣列 arr[0] - arr[2] 中的位置。
[7, 12, 34, 90, 51]
對於 i = 3,arr[3] = 90,將其放置在子數組 arr[0] - arr[3] 的位置。
[7, 12, 34, 90, 51]
對於 i = 4,arr[4] = 51,在子數組 arr[0] - arr[4] 中將其放置在正確的位置。
[7, 12, 34, 54, 90]
在這裡,我們將看到遞歸插入排序的工作原理。它以相反的方式運作,即與當前迭代相比,我們將遞歸呼叫recursiveInsertionSort()函數來對n-1個元素的陣列進行排序。然後在由函數傳回的已排序數組中,我們將第n個元素插入到其在已排序數組中的位置。
遞迴插入排序的程式如下:
範例
示範
#include <stdio.h> void recursiveInsertionSort(int arr[], int n){ if (n <= 1) return; recursiveInsertionSort( arr, n-1 ); int nth = arr[n-1]; int j = n-2; while (j >= 0 && arr[j] > nth){ arr[j+1] = arr[j]; j--; } arr[j+1] = nth; } int main(){ int array[] = {34, 7, 12, 90, 51}; int n = sizeof(array)/sizeof(array[0]); printf("Unsorted Array:\t"); for (int i=0; i < n; i++) printf("%d ",array[i]); recursiveInsertionSort(array, n); printf("</p><p>Sorted Array:\t"); for (int i=0; i < n; i++) printf("%d ",array[i]); return 0; }
輸出
Unsorted Array: 34 7 12 90 51 Sorted Array: 7 12 34 51 90
以上是遞歸插入排序的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)

熱門話題

C++函數的遞歸深度受到限制,超過此限制會導致堆疊溢位錯誤。限制值因係統和編譯器而異,通常在1000到10000之間。解決方法包括:1.尾遞歸最佳化;2.尾呼叫;3.迭代實作。

是的,C++Lambda表達式可以透過使用std::function支援遞歸:使用std::function捕捉Lambda表達式的參考。透過捕獲的引用,Lambda表達式可以遞歸呼叫自身。

遞歸演算法透過函數自呼叫解決結構化的問題,優點是簡潔易懂,缺點是效率較低且可能發生堆疊溢位;非遞歸演算法透過明確管理堆疊資料結構避免遞歸,優點是效率更高且避免堆疊溢出,缺點是程式碼可能更複雜。選擇遞歸或非遞歸取決於問題和實現的特定限制。

給定兩個字串str_1和str_2。目標是使用遞歸過程計算字串str1中子字串str2的出現次數。遞歸函數是在其定義中呼叫自身的函數。如果str1是"Iknowthatyouknowthatiknow",str2是"know"出現次數為-3讓我們透過範例來理解。例如輸入str1="TPisTPareTPamTP",str2="TP";輸出Countofoccurrencesofasubstringrecursi

雙曲函數是使用雙曲線而不是圓定義的,與普通三角函數相當。它從提供的弧度角傳回雙曲正弦函數中的比率參數。但要做相反的事,或者換句話說。如果我們想要根據雙曲正弦值計算角度,我們需要像雙曲反正弦運算一樣的反雙曲三角運算。本課程將示範如何使用C++中的雙曲反正弦(asinh)函數,並使用雙曲正弦值(以弧度為單位)計算角度。雙曲反正弦運算遵循下列公式-$$\mathrm{sinh^{-1}x\:=\:In(x\:+\:\sqrt{x^2\:+\:1})},其中\:In\:是\:自然對數\:(log_e\:k)

遞歸函數是一種在字串處理中反覆呼叫自身來解決問題的技術。它需要一個終止條件以防止無限遞歸。遞歸在字串反轉和回文檢查等操作中被廣泛使用。

rename函數將檔案或目錄從舊名稱變更為新名稱。此操作類似於移動操作。因此,我們也可以使用此rename函數來移動檔案。此函數存在於stdio.h庫頭檔中。 rename函數的語法如下:intrename(constchar*oldname,constchar*newname);rename()函數的函數它接受兩個參數。一個是oldname,一個是newname。這兩個參數都是指向常數字元的指針,用於定義檔案的舊名稱和新名稱。如果檔案重新命名成功,則傳回零;否則,傳回非零整數。在重新命名操作期間

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