-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path1-binary.c
74 lines (65 loc) · 1.37 KB
/
1-binary.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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
#include "search_algos.h"
/**
* print_array - prints array
* @array: sorted array of ints
* @high: upper bound
* @low: lower bound
*/
void print_array(int *array, ssize_t high, ssize_t low)
{
if (low > high)
return;
printf("Searching in array: ");
if (low == high)
{
printf("%u\n", array[high]);
return;
}
while (low <= high)
{
printf("%u", array[low]);
if (low != high)
printf(", ");
low++;
}
printf("\n");
}
/**
* bina_search - binary search helper function
* Recursively searches for value based on midpoint
* @array: sorted array of ints
* @high: top end of array
* @low: lower bound of array
* @value: value to search for
* Return: position or otherwise -1
*/
int bina_search(int *array, ssize_t high, ssize_t low, int value)
{
int mid = low + (high - low) / 2;
print_array(array, high, low);
if (array[mid] == value)
return (mid);
if (high >= low)
{
if (array[mid] > value)
return (bina_search(array, mid - 1, low, value));
else
return (bina_search(array, high, mid + 1, value));
}
return (-1);
}
/**
* binary_search - binary search algorithm
* @array: array of sorted ints
* @size: size of array
* @value: value to serach for
* Return: position or -1 if not found
*/
int binary_search(int *array, size_t size, int value)
{
size_t ret;
if (!array)
return (-1);
ret = bina_search(array, size - 1, 0, value);
return (ret);
}