日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > c/c++ >内容正文

c/c++

动态规划法求最大子段和问题C++

發布時間:2023/12/31 c/c++ 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 动态规划法求最大子段和问题C++ 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

動態規劃法求最大子段和問題

給定由n個整數組成的序列(a1, a2, …, an),求該序列形如(ai, ai+1, ai+2,…, ai+n) 的子段和的最大值,當所有整數均為負整數時,其最大子段和為0。依此定義,所求的最優值為:

動態規劃法代碼如下:

#include <iostream> #include <stdlib.h>using namespace std;int *maxSum(int a[], int b[], int len){int *index;int i;index = (int*)malloc(sizeof(int)*3); //申請空間b[0] = a[0]; //b[0]初始化,將a[0]賦值給b[0]index[0] = b[0]; //假設b[0]是最大子段和index[1] = index[2] = 1; //起始位置的邏輯位置為1for(i=1; i<len; i++){if(b[i-1]>0){ //b[i] = b[i-1]+a[i];}else{ //如果前段和為非正數,舍去,重新尋找子序列b[i] = a[i];index[1] = i+1; //存儲最大子段和左端元素的序數}if(b[i]>index[0]){index[0] = b[i]; //存儲最大子段和的值index[2] = i+1; //存儲最大子段和右端元素的序數}}return index; }int main() {int *max;int a[6] = {-20, 11, -4, 13, -5, -2};int b[6];max = maxSum(a, b, 6);cout << "The largest subsection sum is:" << max[0] << endl;cout << "Start at:" << max[1] << endl;cout << "End at:" << max[2] << endl;return 0; }

總結

以上是生活随笔為你收集整理的动态规划法求最大子段和问题C++的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。