/**
* 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
*
*
* @param nums int整型一维数组
* @param numsLen int nums数组长度
* @param k int整型
* @return int整型
*/
int GetNumberOfK(int* nums, int numsLen, int k ) {
if (nums == NULL || numsLen == 0) {
return 0;
}
int begin = 0, end = numsLen - 1;
int tmplf = 0, tmpri = 0;
int count = 0;
// 确定k这个数是否在数组内
while (begin <= end && k <= nums[end] && k >= nums[begin]) {
int mid = (begin + end) / 2;
if (nums[mid] > k) {
end = mid - 1;
} else if (nums[mid] < k) {
begin = mid + 1;
} else {
tmplf = mid;//找到对应数,可能有多个,所以要查找左和右
tmpri = mid + 1;
break;
}
}
//向左查找k值,并保证不能出界
while (nums[tmplf] == k && tmplf >= 0) {
count++;
tmplf--;
}
//向右查找k值
while (nums[tmpri] == k && tmpri < numsLen) {
count++;
tmpri++;
}
return count;
}