给定一个浮点数n,求它的三次方根。
输入格式
共一行,包含一个浮点数n。
输出格式
共一行,包含一个浮点数,表示问题的解。
注意,结果保留6位小数。
数据范围
−10000≤n≤10000
输入样例:
1000.00
输出样例:
10.000000
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
int main()
{
double x; //要用double不用float,原因见下;
cin>>x;
double l=-10000,r=10000; //初始化时要注意如果求0.01的二次方根,
//0.1不在0-0.01之间,会出错;
while(r-l>=1e-10)
{
double mid=(l+r)/2;
if(mid*mid*mid>=x)r=mid;
else l=mid;
}
printf("%.6f",l);
return 0;
}
,为什么有时候用double对用float就错
我们可以看到,同样的一个数,double可以正确表示出来的数的位数还多;所以有时double对float不对