本文為大家分享了C語言實現(xiàn)分治法實例代碼,供大家參考,具體內(nèi)容如下
創(chuàng)新互聯(lián)于2013年成立,是專業(yè)互聯(lián)網(wǎng)技術(shù)服務公司,擁有項目做網(wǎng)站、網(wǎng)站制作網(wǎng)站策劃,項目實施與項目整合能力。我們以讓每一個夢想脫穎而出為使命,1280元怒江州做網(wǎng)站,已為上家服務,為怒江州各地企業(yè)和個人服務,聯(lián)系電話:028-86922220使用分治法求大值
這個函數(shù)將數(shù)組a[l]...a[r]分成a[l],...,a[m]和a[m+1],...a[r]兩部分,分別求出每一部分的大元素(遞歸地),并返回較大的那一個作為整個數(shù)組的大元素.如果數(shù)組大小是偶數(shù),則兩部分大小相等;如果是奇數(shù),第一部分比第二部分的大小大1.
#include#include #include #include using namespace std; #define OK 1 #define ERROR -1 #define TRUE 1 #define FALSE 0 typedef int Status; int Max(int a[], int l, int r) { int u, v, m = (l + r) / 2; //當區(qū)間中只有一個元素,遞歸終止,并將該元素返回 if(l == r) return a[l]; //遞歸原區(qū)域的左邊 u = Max(a, l, m); //遞歸原區(qū)域的右邊 v = Max(a, m+1, r); //返回大值 return (u>v)?u:v; } int main() { //舉例驗證 int a[7] = {6, 5, 3, 4, 7, 2, 1}; int maxx = Max(a, 0, 6); printf("%d\n", maxx); return 0; }
另外有需要云服務器可以了解下創(chuàng)新互聯(lián)建站www.cdcxhl.com,海內(nèi)外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。