题目:给出一个数组A,找出一对 (i, j)使得A[i] <= A[j] (i <= j)并且j-i最大 ,若有多个这样的位置对,返回i最小的那一对。
最直接的想法就是对于每一个 i 从数组最尾端开始向前找到第一个大于等于 A[i] 的位置 j ,时间复杂度O(n^2)。
pair<int, int> find(const vector<int> &A)
{
int n = A.size();
if(n == 0)
throw new invalid_argument("Array's size can't be 0!");
int target_i = 0, target_j = 0;
int max_len = 0;
for(int i = 0; i < n; ++i)
{
int j;
for(j = n-1; j >= i; --j)
if(A[j] >= A[i])
break;
if(j-i+1 > max_len)
{
target_i = i;
target_j = j;
max_len = j-i+1;
}
}
return make_pair<int, int>(target_i, target_j);
}
我们对上述算法稍作优化。当i=0时,我们假设找到的大于A[i]的最右位置是j0,那么对于i=1时,我们根本就不需要考虑小于j0的位置,因为它们的区间长度都小于j0+1,不可能成为最优解。
pair<int,