-
Notifications
You must be signed in to change notification settings - Fork 16
/
Copy path034-Search for a Range.c
41 lines (41 loc) · 1.06 KB
/
034-Search for a Range.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
/**
* Return an array of size *returnSize.
* Note: The returned array must be malloced, assume caller calls free().
*/
int midsearch(int * nums, int start, int end, int target) {
if (start > end) {
return -1;
}
if (start == end && nums[start] != target) {
return -1;
}
int mid = (start + end) / 2;
if (nums[mid] == target) {
return mid;
} else if (nums[mid] > target) {
return midsearch(nums, start, mid-1, target);
} else {
return midsearch(nums, mid+1, end, target);
}
}
int* searchRange(int* nums, int numsSize, int target, int* returnSize) {
(*returnSize) = 2;
int * ret = malloc(2 * sizeof(int));
int pos = midsearch(nums, 0, numsSize - 1, target);
ret[0] = pos, ret[1] = pos;
if (pos == -1) {
return ret;
}
int i;
for (i = pos - 1 ; i >= 0 ; i--) {
if (nums[i] == target) {
ret[0] = i;
}
}
for (i = pos + 1 ; i < numsSize ; i++) {
if (nums[i] == target) {
ret[1] = i;
}
}
return ret;
}