给出一个时间复杂度为O(n的立方根)的求立方根的算法并解释算法原理
3条回答 默认 最新
- threenewbee 2018-07-11 13:30关注
double cube_root(double a)
{
return cube_root(a, 1.0);
}double cube_root(double a,double x0)
{
double x1,y;
x1=(2*x0+a/(x0*x0))/3.0;
if(fabs(x1-x0)>=0.00001)
y=cube_root(a,x1);
else
y=x1;
return y;
}简单说下,这里x0是猜测值 然后算出这一点的切线和x轴的焦点x1 则有x(真实值)<x1<x0,也就是算出了一个比x0更精确的猜测值 重复以上过程,结果越来越逼近x(真实值),直到得到你需要的精度。
解决 无用评论 打赏 举报
悬赏问题
- ¥15 sqlite 附加(attach database)加密数据库时,返回26是什么原因呢?
- ¥88 找成都本地经验丰富懂小程序开发的技术大咖
- ¥15 如何处理复杂数据表格的除法运算
- ¥15 如何用stc8h1k08的片子做485数据透传的功能?(关键词-串口)
- ¥15 有兄弟姐妹会用word插图功能制作类似citespace的图片吗?
- ¥200 uniapp长期运行卡死问题解决
- ¥15 latex怎么处理论文引理引用参考文献
- ¥15 请教:如何用postman调用本地虚拟机区块链接上的合约?
- ¥15 为什么使用javacv转封装rtsp为rtmp时出现如下问题:[h264 @ 000000004faf7500]no frame?
- ¥15 乘性高斯噪声在深度学习网络中的应用