-
Notifications
You must be signed in to change notification settings - Fork 49
/
binary_search.java
82 lines (71 loc) · 3.22 KB
/
binary_search.java
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
75
76
77
78
79
80
81
82
/**First of all let's understand what is binary search.
* In this algorithm the array taken as input is pre-sorted in any order.
* 1- First of all we compare the search element with the element of the array.If its true then the search is complete.
* 2-If its not , then if the search element is greater than the middle element then for the next time we will search only in the array starting
* from the (mid+1) index and ending at the upperbound of the array.Here mid is the index of the middle element
* 3 - If its less than the middle element then we will search in the array starting at the lowerbound of the array and ending at the index
* (mid+1).
* 4- Thus every time we search in half the array of the previous array.
* 5- Its time complexity is O(log n) which means that its a very efficient algorithm.*/
import java.util.*;
class binary_search
{
public static void main(String[] args)
{
Scanner sc = new Scanner(System.in);
int n,search =0,i = 0,flag = 0;
/*n = Number of elements in the array.
search = The element to search for.
i = The counter variable.
flag = 0 if the element is not found and 1 if the element has been found*/
System.out.println("Enter the number of elements in the array");
n = sc.nextInt();
//Creating an array having n elements.
int array[] = new int[n];
//Taking input into the array elements.
System.out.println("Enter the elements into the array in ascending order.\n");
for(i = 0;i<n;i++)
{
array[i] = sc.nextInt();
}
/*I have assumed that the array is initially sorted in ascending order . If its not sorted we can sort it using any sorting technique.Here
I am only going to show you how the binary search actually works.*/
System.out.println("Enter the element to search for.\n");
search = sc.nextInt();
int l = 0,u = n-1,m = (l+u)/2;
//l = Lower bound of the array to search in.
//u = Upper bound of the array to search in.
//m = Middle element of the array with which we have to compare the search element.
while(l<=u)
{
/*if the search element is greater than the middle element then we will search in the array starting
from the (m+1) index and ending at the upperbound (u) of the array.*/
if(search > array[m])
{
l= m+1;
}
/*If the search element is less than the middle element then we will search in the array starting at the lowerbound (l) of the array and
ending at the index (m+1). */
else if(search < array[m])
{
u = m-1;
}
/*If the search element is equal to the middle element of the array then the search is complete.*/
else
{
flag = 1;
break;
}
//Reinitializing m for the next search.
m = (l+u)/2;
}
if(flag==1)
{
System.out.println("Element "+search+" found at position "+(m+1)+".");
}
else
{
System.out.println("Element not found");
}
}
}