题解 | #求平方根#

求平方根

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;
}

全部评论

相关推荐

CARLJOSEPH...:宝宝你戾气太大了
点赞 评论 收藏
分享
小浪_Coding:找硬件测试,也可兼顾软测欧, 简历还可以的 ,注意排版,项目写的有条理一点, 然后个人技能多加点, 润色好简历之后就开始沟通海投了,深圳,东莞这边做硬件相关的公司还不少, 医疗类,仪器类的都可以尝试
点赞 评论 收藏
分享
Java抽象带篮子:简历怎么写可以看看我发的帖子,你的第一个是实习经历吗?那怎么写的是你的第一个练手项目呢?简历写的怎么样直接投小厂面试一下就知道了
没有实习经历,还有机会进...
点赞 评论 收藏
分享
完美的潜伏者许愿简历...:隐藏信息被你提取出来了,暗示,这就是暗示
点赞 评论 收藏
分享
评论
1
1
分享

创作者周榜

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