首页 > 其他 > 详细

浮点数二分

时间:2019-07-17 19:36:12      阅读:91      评论:0      收藏:0      [点我收藏+]

1.在做浮点数二分的时候需要记住有一个经验值,题目中若是要我们保留6为小数,那么我们的eps需要设置为1e8,(经验值:精确的小数点部分+2)

2.我们在写二分代码的时候需要记得   l = mid, r = mid;

 

代码:

#include <iostream>
#include <cstdio>
using namespace std;

const double eps = 1e-8;

inline double find(double l, double r, double x) {
	
	while(r - l > eps) {
		double mid = (l + r) / 2;
		if(mid * mid * mid >= x) r = mid;
		else l = mid; 
	}
	
	return l;
}

int main(void) {
	double n;
	scanf("%lf", &n);
	
	double t = find(-101, 101, n);
	
	printf("%.6lf\n", t);
	
	return 0;
}

  

浮点数二分

原文:https://www.cnblogs.com/phaLQ/p/11203003.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!