int GetFirstK(int array[], int length, int start, int end, int k) {
if(start > end) { return -1; }
int middle = (start + end) / 2; if(array[middle] == k) {
if((middle > 0 && array[middle - 1] != k) || middle == 0) { return middle; } else { end = middle - 1; } } else if(array[middle] < k) { start = middle + 1; } else { end = middle - 1; }
return GetFirstK(array, length, start, end, k); }
int GetLastK(int array[], int length, int start, int end, int k) {
if(start > end) { return -1; }
int middle = (start + end) / 2; if(array[middle] == k) {
if((middle < length - 1 && array[middle + 1] != k) || middle == length - 1) { return middle; } else { start = middle + 1; } } else if(array[middle] < k) { start = middle + 1; } else { end = middle - 1; }
return GetLastK(array, length, start, end, k); }
int GetNumOfK(int array[], int length, int k) {
if(array == NULL || length <= 0) { throw ("Invalid input."); }
int first = GetFirstK(array, length, 0 , length - 1, k); int last = GetLastK(array, length, 0 , length - 1, k);
if(first > -1 && last > -1) { return last - first + 1; }
return -1; }
|