码迷,mamicode.com
首页 > 编程语言 > 详细

求一维数组最大最大子数组和

时间:2017-03-31 20:56:32      阅读:160      评论:0      收藏:0      [点我收藏+]

标签:下标越界   个数   value   ++   images   设计思想   子数组和   返回   []   

1、设计思想:在while循环里,用 i 控制数组的首位,用 j 控制数组的长度,这样就可以在一个循环里遍历所有子数组,并在循环里求出最大子数组

2、代码

public class MaxValueOfSubArray {

    public static void main(String[] args) {
        // TODO Auto-generated method stub
        int array[] = {2,3,-4,5,-3,-8,7,1,-3};            
        int len = array.length;
        int sum = 0;                            
        for(int i = 0; i < len; i++)
        {
            //求出从i到i+len之间的最大子数组值,如果i+len大于数组长度,则对数组长度取余数
            int temp = getMaxSubArray(array, i, i+len);
            //更新最大子数组的值
            if(temp > sum)
                sum = temp;
            System.out.print(array[i]+" ");
        }
        System.out.println("最大子数组之和为:"+sum);
    }
    
    public static int getMaxSubArray(int[] array,int begin,int end)
    //求数组array在下标begin和end之间的最大子数组之和,如果下标越界,则取下标对数组长度的余数
    {
        int len = array.length;                //求出数组的长度
        if(len <= 0)                        //如果数组不是有效的数组,则返回一个无效的值
            return -1111111111;
        int sum = array[begin];                //sum用来存放子数组之和的最大值,首先赋值为第一个数
        int mark = sum;                        //mark用来标识当前子数组之和,初始化为第一个数
        for(int i = begin+1; i < end; i++)
        {
            if(mark > 0)                    //如果当前子数组之和大于0,则mark加上当前的数字
                mark += array[i%len];
            else                             //如果当前子数组之和小于等于0,则mark从当前数字重新计数
                mark = array[i%len];    
            if(sum < mark)                    //更新sum的值
                sum = mark;
        }
        return sum;
    }
    
}

3、程序截图:

技术分享

4、出现的问题:下表越界,子数组遍历不全

求一维数组最大最大子数组和

标签:下标越界   个数   value   ++   images   设计思想   子数组和   返回   []   

原文地址:http://www.cnblogs.com/shouhutian/p/6653334.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!