给定一个数组,当中有正负数,求当中的一段“子数组”(即任意长度,连续的数字),使得这个“子数组”的和是所有“子数组”和中最大的,
如给定的数组为12, -8, 5, 66, -21, 0 ,35, -44,7,则最大的和的子数组为{12, -8, 5, 66, -21, 0 ,35},最大的和为89.
如给定的数组为12, -8, 5, 66, -21, 0 ,35, -44,7,则最大的和的子数组为{12, -8, 5, 66, -21, 0 ,35},最大的和为89.
package
org.eline.core.utils;
/** */ /**
*
* @author supercrsky
*
*/
public class Test
{
public void findMax(int s[])
{
int add[] = new int[100];
int k = s[0];
int b = 0;// 标记开始位置
int p = 0;// 标记结束位置
int i;
int j;
for (i = 0; i <= s.length; i++)// 整体循环
{
for (j = i; j < s.length; j++)// 子数组循环
{
add[i] += s[j];
if (add[i] > k)
{
k = add[i];
b = i;// 获得开始位置下标
p = j;// 获得结束位置下标
}
}
}
System.out.print("max sub array:");
System.out.print("{");
for (i = b; i <= p; i++)
{
System.out.print(s[i] + " ");
}
System.out.println("}");
System.out.print("sum:" + k);
}
public static void main(String[] args)
{
int s[] =
{ 101, -100, 100, 100, 999, -222 - 100, 100 };
Test test = new Test();
test.findMax(s);
}
}
/** */ /**
*
* @author supercrsky
*
*/
public class Test
{
public void findMax(int s[])
{
int add[] = new int[100];
int k = s[0];
int b = 0;// 标记开始位置
int p = 0;// 标记结束位置
int i;
int j;
for (i = 0; i <= s.length; i++)// 整体循环
{
for (j = i; j < s.length; j++)// 子数组循环
{
add[i] += s[j];
if (add[i] > k)
{
k = add[i];
b = i;// 获得开始位置下标
p = j;// 获得结束位置下标
}
}
}
System.out.print("max sub array:");
System.out.print("{");
for (i = b; i <= p; i++)
{
System.out.print(s[i] + " ");
}
System.out.println("}");
System.out.print("sum:" + k);
}
public static void main(String[] args)
{
int s[] =
{ 101, -100, 100, 100, 999, -222 - 100, 100 };
Test test = new Test();
test.findMax(s);
}
}