码迷,mamicode.com
首页 > 其他好文 > 详细

Maximum Subarray Difference

时间:2015-07-31 18:22:21      阅读:110      评论:0      收藏:0      [点我收藏+]

标签:class   经验   c++   代码   

该题的思路是使用辅助数组来保存从前向后和从后向前到当前位置的最大最小值,这样就可以通过每一个位置处的最大最小值来计算该位置的结果,最后在所有结果中选出最大的值即可。

    int maxDiffSubArrays(vector<int> nums) {
        // write your code here
        int size = nums.size();
        
//以数组中数的个数为维度,定义四个辅助数组
        int *maxArray = new int[size];           
        int *preMinArray = new int[size];
        int *minArray = new int[size];
        int *postMaxArray = new int[size];

//填充辅助数组的值
        maxArray[0] = nums[0];
        preMinArray[0] = nums[0];
        for(int i = 1; i < size; i++){
            maxArray[i] = max(nums[i], nums[i] + maxArray[i - 1]); 
            preMinArray[i] = min(nums[i], nums[i] + preMinArray[i - 1]);
        }
        
        minArray[size - 1] = nums[size - 1];
        minArray[size - 2] = nums[size - 1];
        postMaxArray[size - 1] = nums[size - 1];
        postMaxArray[size - 2] = nums[size - 1];
        
        for(int i = size - 3; i >= 0; i--){
            minArray[i] = min(nums[i + 1], nums[i + 1] + minArray[i + 1]);
            postMaxArray[i] = max(nums[i + 1], nums[i + 1] + postMaxArray[i + 1]);
        }
        
//利用四个辅助数组中的值计算最终的结果
        int result = abs(maxArray[0] - minArray[0]);
        for(int i = 0; i < size - 1; i++){
            if(abs(maxArray[i] - minArray[i]) > result)
                result = abs(maxArray[i] - minArray[i]);
            if(abs(preMinArray[i] - postMaxArray[i]) > result)
                result = abs(preMinArray[i] - postMaxArray[i]);
        }
        
//删除辅助数组
        delete []maxArray;
        delete []minArray;
        delete []preMinArray;
        delete []postMaxArray;
        
        return result;
    }

版权声明:本文为博主原创文章,未经博主允许不得转载。

Maximum Subarray Difference

标签:class   经验   c++   代码   

原文地址:http://blog.csdn.net/ny_mg/article/details/47173177

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