C dilinde bisection methodu

safak563

MB Üyesi
Kayıt
23 Mart 2017
Mesajlar
3
Tepkiler
0
Yaş
27
Üniv
Karadeniz teknik üniversitesi
Arkadaşlar 24.03.2017 ye kadar yetiştirmem gereken bir programlama ödevim var. C dilinde bisection methodu yazmam lazım. Çok çabaladım ama yapamadım.lütfen yardım eder misiniz
 

Mmc

MB Üyesi
Kayıt
23 Mart 2017
Mesajlar
1
Tepkiler
1
Yaş
32
Üniv
University of Massachusetts
#include<stdio.h>
#include<math.h>
float fun (float x)
{
return (x*x*x - 4*x - 9);
}
void bisection (float *x, float a, float b, int *itr)
{
*x=(a+b)/2;
++(*itr);
printf("Iteration no. %3d X = %7.5f\n", *itr, *x);
}
void main ()
{
int itr = 0, maxmitr;
float x, a, b, allerr, x1;
printf("\n a, b Degerlerini gir: \n");
scanf("%f %f %f %d", &a, &b, &allerr, &maxmitr);
bisection (&x, a, b, &itr);
do
{
if (fun(a)*fun(x) < 0)
b=x;
else
a=x;
bisection (&x1, a, b, &itr);
if (fabs(x1-x) < allerr)
{
printf("Iterationdan sonra %d, root = %6.4f\n", itr, x1);
return 0;
}
x=x1;
}
while (itr < maxmitr);
printf("Iterations gecerli degil");
return 1;
}
 
Konu sahibi
Konu sahibi
S

safak563

MB Üyesi
Kayıt
23 Mart 2017
Mesajlar
3
Tepkiler
0
Yaş
27
Üniv
Karadeniz teknik üniversitesi
teşekkürler
 
Yukarı Alt