要求:
1、输入一个整形数组,数组里有正数也有负数。
2、数组中连续的一个或多个整数组成一个子数组,每个子数组都有一个和。
3、如果数组A[0]......A[j-1]首位相邻,允许A[i-1],......A[n-1],A[0]......A[j-1]之和最大。
4、同时返回最大子数组的位置。
5、求所有子数组的和的最大值。
思路:先定义数组个数和长度,通过For循环依次输入数组元素,然后定义Max并赋予第一个数组中的元素。如:int max=a[0];然后定义一个值为数组元素之和s,并且通过For循环和if让s值与max值比较,如if(s>max)则max=s。最后求最大子数组的和。
定义数组的大致代码
int length;
int n;
cout<<"请输入数组元素个数:"<<endl;
cin>>length;
n=2*length;
int *a=new int[n];
定义s值,s值为数组元素之和并且与max值比较的大致代码
int s=0;
for( i=0;i<length;i++)
{
s=0;
for(int j=i;j<length+i;j++)
{
s=s+a[j];
if(s>max)
{
max=s;
}
}
a[length+i]=a[i];
}