leetcode:Sqrt(x)

题目:

Implement int sqrt(int x).

Compute and return the square root of x.


做这道题目,做的真拙计。一开始想到了《最优化理论》里面的类似于二分法的方法,结果竟然超时。十分不解,后来换成了牛顿切线法,表示貌似我实现的是有问题的,我实现没有使用浮点数,在某些输入的情况下是有死循环的。google了之后,结果让我大跌眼镜,竟然是使用了浮点数的牛顿切线法。好吧,不过貌似在学《最优化理论》的时候牛顿切线法的收敛速度是要比那个二分法快的,长记性了。

    int sqrt(int x) {
        // Start typing your C/C++ solution below
        // DO NOT write int main() function
        if (x<0) return -1;
        else if (x==0) return 0;
        else if (x==1 || x==2 || x==3) return 1;
        else if (x==4) return 2;
        
        double start=2;
        double next=(start+x/start)/2;
        
        while (abs(start*start-x)>0.0001)
        {
            start=next;
            next=(start+x/start)/2;
        }
    
        return (int)start;
    }

在google的时候,又发现了一个据说是 最快的开根号的计算方法,竟然是取了一个很变态的初始值的牛顿切线法。

//计算 1 / sqrt(x)
float InvSqrt(float x)
{
 float xhalf = 0.5f*x;
 int i = *(int*)&x; // get bits for floating VALUE
 i = 0x5f375a86- (i>>1); // gives initial guess y0
 x = *(float*)&i; // convert bits BACK to float
 x = x*(1.5f-xhalf*x*x); // Newton step, repeating increases accuracy
 return x;
}

看来老祖宗的东西还是没过时的。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值