该题的思路是使用辅助数组来保存从前向后和从后向前到当前位置的最大最小值,这样就可以通过每一个位置处的最大最小值来计算该位置的结果,最后在所有结果中选出最大的值即可。
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;
}
版权声明:本文为博主原创文章,未经博主允许不得转载。
原文地址:http://blog.csdn.net/ny_mg/article/details/47173177