-
Notifications
You must be signed in to change notification settings - Fork 369
/
Copy pathbisection.c
63 lines (53 loc) · 1.63 KB
/
bisection.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
#include<stdio.h>
#include<math.h>
double F( double x) //Function definition
{
//This return the value of the Function
return (10 - pow(x,2));
}
int main()
{
printf("This program illustrates the bisection method in C:\n");
printf(" f(x) = 10 - x^2");
double x0,x1;
printf("\nEnter the first approximation to the root : ");
scanf("%lf",&x0);
printf("Enter the second approximation to the root : ");
scanf("%lf",&x1);
int iter;
printf("Enter the number of iteration you want to perform : ");
scanf("%d",&iter);
int ctr = 1;
double l1 = x0;
double l2 = x1;
double r,f1,f2,f3;
//We check if the initial approximations are the root or not
if(F(l1)==0)// it is a root
r = l1;
else if(F(l2)==0)
r = l2;
else //If the above two values are not the roots of the given function
{
while(ctr <= iter) //Since, ctr is initialized to 1
{
//This is an implementation of the algorithm mentioned above
f1 = F(l1);
r = (l1+l2)/2.0; //Returns a double value
f2 = F(r);
f3 = F(l2);
if(f2 == 0)
{
r = f2;
break; //Execution moves out of the while loop to the statement just after it
}
printf("The root after %d iteration is %lf\n",ctr,r);
if(f1*f2 < 0)//Both are of opposite sign
l2 = r;
else if(f2*f3 < 0)
l1 = r;
ctr++;
}
}
printf("The approximation to the root is %lf\n",r); //Gives the final value after mentioned iteration
return 0;
}