国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學(xué)院 > 開發(fā)設(shè)計 > 正文

最大子數(shù)組問題

2019-11-09 21:09:44
字體:
供稿:網(wǎng)友

問題描述: 給定一個整數(shù)數(shù)組,找到一個具有最大和的子數(shù)組,返回其最大和。

樣例: 給出數(shù)組[?2,2,?3,4,?1,2,1,?5,3],符合要求的子數(shù)組為[4,?1,2,1],其最大和為6

分析: 解決這個問題至少有4種方法

算法1 窮舉法

我們窮舉出所有的子數(shù)組,然后從這些子數(shù)組中找出最大的

int MaxSubseqSum1(int List[], int N){ int ThisSum, MaxSum = 0; int i,j,k; for (i = 0; i < N; i++)//i是子數(shù)組的左端 { for (j = i; j < N; j++)//j是子數(shù)組的右端 { ThisSum = 0;//ThisSum是List[i]到List[j]的子數(shù)組的和 for (k = i; k <= j; k++) ThisSum += List[k]; if(ThisSum > MaxSum)//如果剛得到的這個子數(shù)組和更大 MaxSum = ThisSum;//則更新結(jié)果 } } return MaxSum;}

時間復(fù)雜度O(N3)

算法2 優(yōu)化的窮舉法

第一個算法中,最里面的循環(huán),對于固定的i,當j增大了1,k循環(huán)需要從新從i加到j。事實上,第j部就加上List[j]即可。

int MaxSubseqSum2(int List[], int N){ int ThisSum, MaxSum = 0; int i,j; for (i = 0; i < N; i++) { ThisSum = 0; for (j = i; j < N; j++) { ThisSum += List[j]; // 對于相同的i,不同的j,只要在j-1次循環(huán)的基礎(chǔ)上累加1項即可 if(ThisSum > MaxSum) MaxSum = ThisSum; } } return MaxSum;}

時間復(fù)雜度O(N2)

算法3:分而治之

步驟: 1. 將序列分為左右兩個子數(shù)組 2. 遞歸地求兩個子數(shù)組的最大和S左S右 3. 從中間的點分別找出左右,跨過分界線的最大子數(shù)組的和S中 4. Smax=maxS左,S右,S中

/*算法3:分而治之*/inx Max3(int A, int B, int C){ return A > B ? A > C ? A : C : B > C ? B : C;}int DivideAndConquer(int List[], int left, int right){ int MaxLeftSum, MaxRightSum; int MaxLeftBorderSum, MaxRightBorderSum; int LeftBorderSum, RightBorderSum; int center,i; if(left == right) //遞歸終止條件,子數(shù)組只有一個數(shù)字 if(List[left] > 0) return List[left]; else return 0; //分的過程 center = (left+right)/2; MaxLeftSum = DivideAndConquer(List,left,center) MaxRightSum = DivideAndConquer(List,center+1,right) //跨界求最大子數(shù)組和 MaxLeftBorderSum = 0; LeftBorderSum = 0; for (i = center; i >= left; i--) { LeftBorderSum += List[i]; if(LeftBorderSum > MaxLeftBorderSum) MaxLeftBorderSum = LeftBorderSum; }//左邊掃描結(jié)束 MaxRightBorderSum = 0; RightBorderSum = 0; for (i = center+1; i < right; i++) { RightBorderSum += List[]; if(RightBorderSum > MaxRightBorderSum) MaxRightBorderSum = RightBorderSum; }//右邊掃描結(jié)束 //治的過程 return Max3(MaxLeftSum,MaxRightSum,MaxLeftBorderSum+MaxRightBorderSum);}int MaxSubseqSum3(int List[], int N){ return DivideAndConquer(List, 0, N-1);}

算法4:在線處理(動態(tài)規(guī)劃)

核心思想:一旦發(fā)現(xiàn)子數(shù)組的和為負數(shù),棄置,重新一個新數(shù)組。

int MaxSubseqSum4(int List[], int N){ int ThisSum, MaxSum; int int; ThisSum = MaxSum = 0; for (i = 0; i < N; i++) { ThisSum += List[i]; if(ThisSum > MaxSum) MaxSum = ThisSum; else if(ThisSum < 0) ThisSum = 0; } return MaxSum;}

python

#動態(tài)規(guī)劃def MaxSubseqSum(A): max_ending_here = max_so_far = A[0] for x in A[1:]: max_ending_here = max(x, max_ending_here + x) max_so_far = max(max_so_far, max_ending_here) return max_so_far
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 红桥区| 兖州市| 抚宁县| 广灵县| 广安市| 华阴市| 二手房| 余姚市| 永康市| 安国市| 杂多县| 枣庄市| 大厂| 墨玉县| 哈尔滨市| 黄平县| 和硕县| 肥东县| 澎湖县| 昌都县| 伊吾县| 依兰县| 江山市| 盘锦市| 察隅县| 临城县| 青州市| 任丘市| 崇明县| 临漳县| 中江县| 崇仁县| 资中县| 东源县| 武定县| 聂拉木县| 天等县| 长寿区| 弋阳县| 毕节市| 盖州市|