问题描述:(acwing790题)
给定一个浮点数 n,求它的三次方根。
输入格式
共一行,包含一个浮点数 n。
输出格式
共一行,包含一个浮点数,表示问题的解。
注意,结果保留 6位小数。
数据范围
−10000≤n≤10000
问题分析:
本体比较简单,直接采用二分法逼近数的极限,而不需要像整数一样考虑数的边界值。
下面是c++代码演示
#include<iostream>
#include<iomanip>
using namespace std;
int main() {
double x;
cin >> x;
double l = -10000;
double r = 10000;
while (r - l > 10e-8) {
double mid = (l + r) / 2;
if (mid * mid * mid >= x) r = mid;
else l = mid;
}
cout <<fixed<<setprecision(6)<< l << endl;
}
本体演示的是开三次方根,基本上的二分思想和DAY1保持一致,但是由于是浮点数,就不用考虑数的边界值了。
此外本题还需注意的一个点是while(r-l>10e-8),题目上写的是取小数点后六位,但是此处区间范围在10e-8之内,那是为了避免结果因为四舍五入导致出现偏差,这么做最多也就是小数点后第七位可能会出现四舍五入,1~6位与实际相符。
综合来看,本题属于掌握二分法就能上的简单题