二分法实现开方运算

public int sqrt(int x) {
        int low = 0;
        int high = x;
        while (low <= high) {
            long mid = (low + high) / 2;//防止溢出
            if (mid * mid == x)
                return (int) mid;
            else if (mid * mid < x)
                low = (int) (mid + 1);
            else
                high = (int) (mid - 1);
        }
        return high;
    }
}
全部评论

相关推荐

不愿透露姓名的神秘牛友
09-30 19:49
起名星人:蛮离谱的,直接要求转投销售
投递汇川技术等公司10个岗位
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务