浮點數二分演算法:790. 數的三次方根
阿新 • • 發佈:2021-01-27
技術標籤:演算法
給定一個浮點數n,求它的三次方根。
輸入格式
共一行,包含一個浮點數n。
輸出格式
共一行,包含一個浮點數,表示問題的解。
注意,結果保留6位小數。
資料範圍
−10000≤n≤10000
輸入樣例:
1000.00
輸出樣例:
10.000000
經驗值:
當結果保留6位小數時,r-l = 1e-8;
當結果保留5位小數時,r-l = 1e-7;
往後多開兩位
#include <iostream>
using namespace std;
int main()
{
double x;
cin>>x;
double l = -10000, r = 10000;
while (r - l >=1e-8)
{
double mid = (l + r )/2;
if(mid*mid*mid>=x) r = mid;
else l = mid;
}
printf("%lf",l);
return 0;
}
}
**另一種演算法:直接呼叫庫函式
#include<cstdio>
#include<cmath>
int main(){
double a;
scanf("%lf",&a);
printf ("%.6lf",cbrt(a));
return 0;
}