题解 | #求平方根#

求平方根

http://www.nowcoder.com/practice/09fbfb16140b40499951f55113f2166c

//标准二分法
int Sqrt(int x ) {
        //特殊处理
    if(x<2) return x;
        //长整型防止溢出;平方根一定小于或等于中值,使用X/2会快一点。
    long int  left = 0;
    long int right = x/2;
        //左闭右闭
    while(left<=right){
                //先减后加防止溢出(好习惯),移位加快运算。
        long int middle = left + ((right-left)>>1);
                //修改区间
        if(middle*middle > x){
            right = middle -1;
        }
        else if(middle*middle < x){
            left = middle + 1;
        }
        else return middle;
    }
        //如果没找到,例如2的平方根约为1.4,此时right指向1,left指向2=(middle+1),返回right即可。
    return right;
}

全部评论

相关推荐

奔跑的suechil...:怎么评论区这么多打广告的 1.项目考虑是两个,可以加个项目 2.bg一般的话,不建议外卖加点评,99%都过不了简历 3.找项目要么是自己找github好点的开源,要么是评论区找广告去跟着,要么就是星球找项目了 加油友友
点赞 评论 收藏
分享
评论
1
1
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务