Add jump search java program (#24)
* Add binary search javascript program * Add jump-search-java program * Delete stdout.txtpull/26/head
parent
5c6c97f757
commit
ec35fca77d
|
@ -19,5 +19,6 @@
|
||||||
|
|
||||||
1. [Linear Search](java/linear-search.java)
|
1. [Linear Search](java/linear-search.java)
|
||||||
2. [Binary Search](java/binary-search.java)
|
2. [Binary Search](java/binary-search.java)
|
||||||
|
3. [Jump Search](java/jump-search.java)
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,55 @@
|
||||||
|
// Java program to implement Jump Search.
|
||||||
|
public class JumpSearch
|
||||||
|
{
|
||||||
|
public static int jumpSearch(int[] arr, int x)
|
||||||
|
{
|
||||||
|
int n = arr.length;
|
||||||
|
|
||||||
|
// Finding block size to be jumped
|
||||||
|
int step = (int)Math.floor(Math.sqrt(n));
|
||||||
|
|
||||||
|
// Finding the block where element is
|
||||||
|
// present (if it is present)
|
||||||
|
int prev = 0;
|
||||||
|
while (arr[Math.min(step, n)-1] < x)
|
||||||
|
{
|
||||||
|
prev = step;
|
||||||
|
step += (int)Math.floor(Math.sqrt(n));
|
||||||
|
if (prev >= n)
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Doing a linear search for x in block
|
||||||
|
// beginning with prev.
|
||||||
|
while (arr[prev] < x)
|
||||||
|
{
|
||||||
|
prev++;
|
||||||
|
|
||||||
|
// If we reached next block or end of
|
||||||
|
// array, element is not present.
|
||||||
|
if (prev == Math.min(step, n))
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
// If element is found
|
||||||
|
if (arr[prev] == x)
|
||||||
|
return prev;
|
||||||
|
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Driver program to test function
|
||||||
|
public static void main(String [ ] args)
|
||||||
|
{
|
||||||
|
int arr[] = { 0, 1, 1, 2, 3, 5, 8, 13, 21,
|
||||||
|
34, 55, 89, 144, 233, 377, 610};
|
||||||
|
int x = 55;
|
||||||
|
|
||||||
|
// Find the index of 'x' using Jump Search
|
||||||
|
int index = jumpSearch(arr, x);
|
||||||
|
|
||||||
|
// Print the index where 'x' is located
|
||||||
|
System.out.println("\nNumber " + x +
|
||||||
|
" is at index " + index);
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue