第20727题 单选
下述实现归并排序的C++代码中,merge函数内的横线上应填写的代码是什么?
void merge(vector<int> &nums, int left, int mid, int right) {    
    // 左子数组区间为 [left, mid], 右子数组区间为 [mid+1, right]    
    vector<int> tmp(right - left + 1);    
    int i = left, j = mid + 1, k = 0;    
    while (i <= mid && j <= right) {        
        if (nums[i] <= nums[j])            
            tmp[k++] = nums[i++];        
        else            
            tmp[k++] = nums[j++];    
    }    
    while (i <= mid) {        
        tmp[k++] = nums[i++];    
    }    
    while (________) { // 在此处填入代码        
        tmp[k++] = nums[j++];    
    }    
    for (k = 0; k < tmp.size(); k++) {        
        nums[left + k] = tmp[k];    
    }
}
void mergeSort(vector<int> &nums, int left, int right) {    
    if (left >= right)        
        return;    
    int mid = (left + right) / 2;    
    mergeSort(nums, left, mid);    
    mergeSort(nums, mid + 1, right);    
    merge(nums, left, mid, right);
}
A

i < mid

B

j < right

C

i <= mid

D

j <= right