解题思路:按题目要求来,用二分法搜索可认为相等的近似值
注意事项:
参考代码:
#include <iostream> #include <cmath> #include <iomanip> using namespace std; #define PI 3.1415926 int main() { double x,left,right,mid; cin>>x; left=0;right=PI; while(true) { if(fabs(cos(mid)-x)<0.00000000001)//两个差值足够小,可认为相等 { cout<<setiosflags(ios::fixed)<<setprecision(5)<<mid<<endl; break; } else if(x<cos(mid))//太大 left=mid; else if(x>cos(mid))//太小 right=mid; mid=(left+right)/2;//二分法搜索 (对二进制数进行操作,会更快mid=(left+right)>>1;(右移1个) } return 0; }
0.0分
0 人评分
C语言程序设计教程(第三版)课后习题4.9 (C语言代码)浏览:949 |
C语言程序设计教程(第三版)课后习题1.6 (C++代码)浏览:909 |
C语言程序设计教程(第三版)课后习题8.3 (C语言代码)浏览:624 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:541 |
C语言程序设计教程(第三版)课后习题6.5 (C++代码)浏览:487 |
IP判断 (C语言代码)浏览:820 |
C语言程序设计教程(第三版)课后习题5.5 (C语言代码)浏览:582 |
杨辉三角 (C语言代码)浏览:505 |
简单的事情 (C语言代码)浏览:679 |
C语言程序设计教程(第三版)课后习题7.3 (C语言代码)浏览:420 |