1007(最大子串和)

来源:互联网 发布:淘宝代销怎么上传宝贝 编辑:程序博客网 时间:2024/06/03 22:00
#include <iostream>using namespace std;const int MAX = 10000;int a[MAX];void findij(const int array[], size_t length, unsigned int& i, unsigned int& j, const int& max){int cur_max;for(i = 0; i <length; i++){cur_max = 0;for(j=i; j<length; j++){cur_max  += array[j];if(max == cur_max)return;}}}int Kadane(const int array[], size_t length, unsigned int& left, unsigned int& right){unsigned int i, cur_left, cur_right;int cur_max, max;cur_max = max = left = right = cur_left = cur_right = 0;for(i = 0; i < length; ++i){cur_max += array[i];if(cur_max > 0){cur_right = i;if(max < cur_max){max = cur_max;left = cur_left;right = cur_right;}}else{cur_max = 0;cur_left = cur_right = i + 1;}}return max;}int main(){unsigned int i, j;size_t count;bool flag = true;cin>>count;for(i=0; i<count; i++){cin>>a[i];if(a[i]>=0)flag = false;}if(flag){cout<<0<<" "<<a[0]<<" "<<a[count-1]<<endl;}else{int max = Kadane(a, count, i, j);findij(a, count, i, j, max);cout<<max<<" "<<a[i]<<" "<<a[j]<<endl;}return 0;}

原创粉丝点击