01 複雜度1 最大子列和問題 20分

2021-10-06 12:17:31 字數 1286 閱讀 2909

給定k個整數組成的序列,「連續子列」被定義為,其中 1≤i≤j≤k。「最大子列和」則被定義為所有連續子列元素的和中最大者。例如給定序列,其連續子列有最大的和20。現要求你編寫程式,計算給定整數序列的最大子列和。

本題旨在測試各種不同的演算法在各種資料情況下的表現。各組測試資料特點如下:

資料1:與樣例等價,測試基本正確性;

資料2:102個隨機整數;

資料3:103個隨機整數;

資料4:104個隨機整數;

資料5:105個隨機整數;

輸入第1行給出正整數k (≤100000);第2行給出k個整數,其間以空格分隔。

輸出格式:

在一行中輸出最大子列和。如果序列中所有整數皆為負數,則輸出0。

6-2 11 -4 13 -5 -2

**長度限制

16 kb

時間限制

50000 ms

記憶體限制

64 mb

#includeusing namespace  std;

int max3(int a, int b, int c)

//方法1 分治法 時間複雜度為nlogn

int fenzi(int* list, int left, int right)

int mid = (left + right) / 2;

maxleftpart = fenzi(list, left, mid);

maxrightpart = fenzi(list, mid + 1, right);

int lsummax = 0;

for (int i = mid; i >= left; i--) }

int rsummax = 0;

for (int i = mid + 1; i <= right; i++) }

return max3(maxleftpart, maxrightpart, lsummax + rsummax);

}//方法二:流水線處理 時間複雜度 n

int realtimeprocess(int n, int* list) else if (sum < 0) }

return maxsum;

}//公共介面 只需修改內容體中呼叫的函式

int findmax(int n, int* list)

int main()

int res = findmax(k, list);

printf("%d", res);

return 0;

}

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個整數,其間以空格分隔。輸出格式...