-
Notifications
You must be signed in to change notification settings - Fork 1.1k
/
Jump_Search.cpp
78 lines (72 loc) · 1.55 KB
/
Jump_Search.cpp
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
/*JUMP SEARCH:
Jump Search is a searching algorithm for sorted arrays.
The basic idea is to check fewer elements (than linear search) by jumping ahead by fixed steps or skipping some elements in place of searching all elements.
*/
#include<iostream>
#include<cmath>
using namespace std;
int jump_search(int a[], int n, int find)
{
int step = sqrt(n);
int pre_step = 0;
while (a[min(step, n) - 1] < find)
{
pre_step = step;
step += sqrt(n);
if (pre_step >= n)
{
return -1;
}
}
while(a[pre_step] < find)
{
pre_step++;
if(pre_step == min(step,n))
{
return -1;
}
}
if(a[pre_step] == find)
{
return pre_step;
}
else
{
return -1;
}
}
int main()
{
int n,search;
cout << "Enter no. of elements in an array: ";
cin >> n;
int arr[n];
cout << "Enter elements in an array in increasing order: ";
for(int i=0;i<n;i++)
{
cin >> arr[i];
}
cout << "Enter a number to be searched: ";
cin >> search;
int result = jump_search(arr,n,search);
if(result == -1)
{
cout << search << " is not present in the array." << endl;
}
else
{
cout << search << " is present at index no " << result+1 << endl;
}
return 0;
}
/*
SAMPLE INPUT:
Enter no. of elements in an array:
12
Enter elements in an array in increasing order:
2 4 6 8 10 11 14 17 20 33 36 40
Enter a number to be searched:
17
SAMPLE OUTPUT:
17 is present at index no 8
*/