★实验任务读数学的小渣最近遇到了个棘手的问题,要求 y= log(a)x+bx+c=0(a>1,b>=0)的根。而他现在忙着推理公式,所以要你帮他写个程序来完成这个问题。
★数据输入输入第一行包括三个实数 a,b,c。
★数据输出输出方程式的根 x(保留 5 位小数)。
输入示例
2 2 2
输出示例
0.19167
#include<stdio.h>
#include<math.h>
#define eps 1e-9
double a,b,c,l,r,mid;
int main(){
scanf("%lf%lf%lf",&a,&b,&c);
for(l=0,r=10000,mid=(l+r)/2;l<=r;mid=(l+r)/2,log(mid)/log(a)+b*mid+c>0?r=mid-eps:l=mid+eps);
printf("%.5lf",l+eps);
return 0;
}
二分法