题目描述
给定一个浮点数n,求它的三次方根。
输入格式
共一行,包含一个浮点数n。
输出格式
共一行,包含一个浮点数,表示问题的解。
注意,结果保留6位小数。
数据范围
−10000≤n≤10000
样例
输入样例:
1000.00
输出样例:
10.000000
算法
浮点数二分
思路
1:在题目给的数据范围内,二分查找,一次次的比较,直到找到答案,注意高精度(小数比较要注意保留几位小数位数,一般来说1e-8)
2:可以适当的使用库函数cbrt(),这个更简单
C++ 代码
#include<iostream>
#include<iomanip>
using namespace std;
double n;
int main ()
{
scanf("%lf",&n);
double l=-10000,r=10000;
while(r-l>=1e-8)
{
double mid=(l+r)/2;
if(mid*mid*mid>n) r=mid;
else l=mid;
//cout<<l<<endl;
}
printf("%.6f",l);
return 0;
}