Skip to content

Commit

Permalink
Day 28, 29 - C (#208)
Browse files Browse the repository at this point in the history
* Create Linear_Search.c

* Update README.md

* Create Binary_Search.c

* Update README.md

* Update README.md
  • Loading branch information
ashwek authored and MadhavBahl committed Feb 8, 2019
1 parent dfbd035 commit 50606ca
Show file tree
Hide file tree
Showing 4 changed files with 224 additions and 2 deletions.
46 changes: 46 additions & 0 deletions day28/C/Linear_Search.c
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
/*
* @author : ashwek
* @date : 29/01/2019
*/

#include <stdio.h>
#include <stdlib.h>

int linear_search(int *arr, int n, int search){

int i;

for(i=0; i<n; i++){
if( arr[i] == search )
return i;
}

return -1;
}

void main(){

int *arr, n, search, i;

printf("Enter size of array = ");
scanf("%d", &n);

arr = (int *)malloc(sizeof(int)*n);

printf("Enter %d elements : ", n);
for(i=0; i<n; i++){
scanf("%d", &arr[i]);
}

printf("Enter a value to search = ");
scanf("%d", &search);

i = linear_search(arr, n, search);

if( i == -1 ){
printf("%d not found in array", search);
}
else{
printf("%d found at %d index", search, i);
}
}
55 changes: 54 additions & 1 deletion day28/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -73,4 +73,57 @@ public class linearSearch1 {
System.out.println("undefined");
}
}
```
```

## C Implementation

### [Solution](./C/Linear_Search.c)

```c
/*
* @author : ashwek
* @date : 29/01/2019
*/

#include <stdio.h>
#include <stdlib.h>

int linear_search(int *arr, int n, int search){

int i;

for(i=0; i<n; i++){
if( arr[i] == search )
return i;
}

return -1;
}

void main(){

int *arr, n, search, i;

printf("Enter size of array = ");
scanf("%d", &n);

arr = (int *)malloc(sizeof(int)*n);

printf("Enter %d elements : ", n);
for(i=0; i<n; i++){
scanf("%d", &arr[i]);
}

printf("Enter a value to search = ");
scanf("%d", &search);

i = linear_search(arr, n, search);

if( i == -1 ){
printf("%d not found in array", search);
}
else{
printf("%d found at %d index", search, i);
}
}
```
58 changes: 58 additions & 0 deletions day29/C/Binary_Search.c
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
/*
* @author : ashwek
* @date : 29/01/2019
*/

#include <stdio.h>
#include <stdlib.h>

int binary_search(int *arr, int n, int search){

int low = 0, high = n-1;
int mid;

while( low <= high ){

mid = (high - low) / 2 + low;

if( arr[mid] == search ){
return mid;
}
else if( search < arr[mid] ){
high--;
}
else{
low++;
}

}

return -1;
}

void main(){

int *arr, n, search, i;

printf("Enter size of array = ");
scanf("%d", &n);

arr = (int *)malloc(sizeof(int)*n);

printf("Enter %d elements (in sorted order) : ", n);
for(i=0; i<n; i++){
scanf("%d", &arr[i]);
}

printf("Enter a value to search = ");
scanf("%d", &search);

i = binary_search(arr, n, search);

if( i == -1 ){
printf("%d not found in array", search);
}
else{
printf("%d found at %d index", search, i);
}
}
67 changes: 66 additions & 1 deletion day29/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,71 @@ console.log (binarySearch ([1, 2, 3, 4, 5, 8, 9], 8));
console.log (binarySearch ([1, 2, 3, 4, 5, 8, 9], 7));
```

### C Implementation

## [Solution](./C/Binary_Search.c)

```c
/*
* @author : ashwek
* @date : 29/01/2019
*/

#include <stdio.h>
#include <stdlib.h>

int binary_search(int *arr, int n, int search){

int low = 0, high = n-1;
int mid;

while( low <= high ){

mid = (high - low) / 2 + low;

if( arr[mid] == search ){
return mid;
}
else if( search < arr[mid] ){
high--;
}
else{
low++;
}

}

return -1;
}

void main(){

int *arr, n, search, i;

printf("Enter size of array = ");
scanf("%d", &n);

arr = (int *)malloc(sizeof(int)*n);

printf("Enter %d elements (in sorted order) : ", n);
for(i=0; i<n; i++){
scanf("%d", &arr[i]);
}

printf("Enter a value to search = ");
scanf("%d", &search);

i = binary_search(arr, n, search);

if( i == -1 ){
printf("%d not found in array", search);
}
else{
printf("%d found at %d index", search, i);
}
}
```
## Java Implementation
### [Solution](./Java/binarySearch.java)
Expand Down Expand Up @@ -151,4 +216,4 @@ int main(){
cout << "Recursive: " << binary_search_rec(arr, 0, size-1, val) << endl;
return 0;
}
```
```

0 comments on commit 50606ca

Please sign in to comment.