首页 > 代码库 > UVA 10341
UVA 10341
UVA 10341
主要是要知道这个函数是单调递减的,这样就好做了。
1 #include <bits/stdc++.h> 2 #define ll long long 3 using namespace std; 4 double p,q,r,s,t,u; 5 double fun(double x){ 6 return p*exp(-x)+q*sin(x)+r*cos(x)+s*tan(x)+t*(x)*(x)+u; 7 } 8 int main(){ 9 while(scanf("%lf %lf %lf %lf %lf %lf",&p,&q,&r,&s,&t,&u)!=EOF){ 10 if(fun(0) < 0 || fun(1) > 0){ 11 printf("No solution\n"); 12 continue; 13 } 14 int flag = 0; 15 double i = 0, j = 1, mid; 16 while(1){ 17 mid = (i+j)/2.0; 18 if(fabs(fun(mid)) < 1e-9){ 19 printf("%.4lf\n",mid); 20 flag = 1; 21 break; 22 } 23 if(fun(mid) > 0) i = mid; 24 else if(fun(mid) < 0) j = mid; 25 } 26 if(!flag)printf("No solution\n"); 27 } 28 return 0; 29 }
UVA 10341
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。