我正在尝试运行以下代码:
int across(vector<int> &nums, int l , int m, int h){
int i = l, j = m +1;
int count = 0;
unsigned long long int n;
unsigned long long int prev;
while(i <= m && j <=h){
n = 2* nums[j];
prev = nums[i];
if(prev > n){
count += m - i +1;
j++;
}
else{
i++;
}
}
return count;
}
Run Code Online (Sandbox Code Playgroud)
nums 是一个从索引 l 到 m 以及从索引 m+1 到 h 排序的向量。我必须计算对(i,j)的数量,这样nums[i] > 2 * nums[j]
当其中一个元素为 …