-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathSearch.c
181 lines (130 loc) · 3.47 KB
/
Search.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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
/*Write a program to search an element from a given array by using following methods:
-->Linear Search
-->Binary Search
It will show whether searching element is present or not.If present it will show the position of the element*/
#include<stdio.h>
#include<stdlib.h>
//Sorting algorithm
void sort(int arr[],int size){
for(int i = 0;i < size;i++){
for (int j = 0; j < size-i-1; j++)
{
/* code */
if(arr[j]>arr[j+1]){
int tmp = arr[j];
arr[j]=arr[j+1];
arr[j+1]=tmp;
}
}
}
}
//binary search function
int binarySearch(int arr[],int size,int item){
sort(arr,size);//sort the array if not sorted
// //printing the sorted array
// printf("\nThe sorted array is:");
// for(int i = 0;i < size;i++){
// printf("%d\n",arr[i]);
// }
int lb = 0,up = size - 1,mid,pos;
mid = (lb+((up - lb)/2));
while(lb <= up){
if(arr[mid] == item){
pos = mid;
return pos;
}
if(arr[mid]<item){
lb = mid +1;
}
if(arr[mid]>item){
up = mid - 1;
}
}
return -1;
}
//linear search function
int linearSearch(int arr[],int size,int item){
int pos;
for(int i = 0;i < size;i++){
if(item == arr[i]){
pos = i;
return pos;
}
}
return -1;
}
// //Sorting algorithm
// void sort(int arr[],int size){
// for(int i = 0;i < size;i++){
// for (int j = 0; j < size-i-1; j++)
// {
// /* code */
// if(arr[j]>arr[j+1]){
// int tmp = arr[j];
// arr[j]=arr[j+1];
// arr[j+1]=tmp;
// }
// }
// }
// }
//The main function
int main(){
int *ptr,element,n;
printf("\nEnter the size of the array:");
scanf("%d",&n);
ptr = (int *)malloc(n*sizeof(int));//dynamic memory allocation of array
printf("\nEnter the elements in the array:");//Enter elements in the array
for(int i = 0; i < n;i++){
scanf("%d",&ptr[i]);
}
printf("\nEnter element to be searched:");//Entering the element to be searched
scanf("%d",&element);
int choice;
printf("\nEnter your choice:\n1.Linear Search\n2.Binary Search\n");
//Choose which searching to be performed
scanf("%d",&choice);
printf("\n----------------------Menu------------------------------\n");
int f_1,f_2;
// f_1 = linearSearch(ptr,n,element);
// f_2 = binarySearch(ptr,n,element);
//Menu
switch (choice)
{
case 1:
/* linear search */
// linearSearch(ptr,n,element);//call linearSearch function
f_1 = linearSearch(ptr,n,element);
if(f_1 == -1){
printf("\nElement absent!!\n");
}
else{
printf("\nElement present at position %d\n",f_1);
}
break;
case 2:
/* binary search */
// sort(ptr,n);//sort the array if not sorted
//print the sorted array
// printf("\nThe sorted array is:");
// for(int i = 0;i < n;i++){
// printf("\t%d\n",ptr[i]);
// }
binarySearch(ptr,n,element);//call binarySearch function
f_2 = binarySearch(ptr,n,element);
// printf("\nThe sorted array is:");
// for(int i = 0;i < n;i++){
// printf("%d\n",ptr[i]);
// }
if(f_2 == -1){
printf("\nElement absent!!\n");
}
else{
printf("\nElement is present at position %d\n",f_2);
}
break;
default:
printf("\nWrong choice!!\nEnter a valid option\n");
break;
}
return 0;
}