01-複雜度1 最大子列和問題 (20分)
給定kk
個整數組成的序列,「連續子列」被定義為n
i+1
, ..., n_jn
j },其中 1 \le i \le j \le k1≤
i≤j≤
k。「最大子列和」則被定義為所有連續子列元素的和中最大者。例如給定序列,其連續子列有最大的和20。現要求你編寫程式,計算給定整數序列的最大子列和。
本題旨在測試各種不同的演算法在各種資料情況下的表現。各組測試資料特點如下:
輸入第1行給出正整數k
k (\le 100000≤1
0000
0);第2行給出k
k個整數,其間以空格分隔。
在一行中輸出最大子列和。如果序列中所有整數皆為負數,則輸出0。
6
-2 11 -4 13 -5 -2
20
#includeusing namespace std;
int a[100001];
int max(int x,int y,int z)
int zuidazilie(int t,int left,int right)
else
}int leftvalue,rightvalue;
center=(left+right)/2;
leftvalue=zuidazilie(t,left,center);
rightvalue=zuidazilie(t,center+1,right);
int maxleftborder=0,maxrightborder=0;
int leftborder=0,rightborder=0;
for(i=center;i>=left;i--) }
for(i=center+1;i<=right;i++) }
return max(maxleftborder+maxrightborder,leftvalue,rightvalue);
}int main()
int ans=zuidazilie(a,0,n-1);
cout<
01 複雜度1 最大子列和問題 20
時間限制 10000 ms 記憶體限制 65536 kb 長度限制 8000 b 判題程式 standard 給定k個整數組成的序列,連續子列 被定義為,其中 1 i j k。最大子列和 則被定義為所有連續子列元素的和中最大者。例如給定序列,其連續子列有最大的和20。現要求你編寫程式,計算給定整數序...
01 複雜度1 最大子列和問題 20
programming ability test 給定k個整數組成的序列,連續子列 被定義為,其中 1 i j k。最大子列和 則被定義為所有連續子列元素的和中最大者。例如給定序列,其連續子列有最大的和20。現要求你編寫程式,計算給定整數序列的最大子列和。輸入格式 輸入第1行給出正整數 k 1000...
01 複雜度1 最大子列和問題 20
給定k個整數組成的序列,連續子列 被定義為,其中 1 i j k。最大子列和 則被定義為所有連續子列元素的和中最大者。例如給定序列,其連續子列有最大的和20。現要求你編寫程式,計算給定整數序列的最大子列和。輸入格式 輸入第1行給出正整數 k 100000 第2行給出k個整數,其間以空格分隔。輸出格式...