题解 | 求平方根

求平方根

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

class Solution {
  public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     *
     * @param x int整型
     * @return int整型
     */
    //注意题目要求的数据范围,我用的unsigned long
    int mysqrt(unsigned long x) {
        unsigned long i = x / 2;
        unsigned long j = x;
        //二分法确定答案的一个大致的范围  
        while (1) {
            if (i * i > x) {
                j = i;
                i /= 2;
            } else {
                break;
            }
        }
        unsigned long k = i;
        //cout << "i=" << i << endl << "j=" << j << endl;
        //常规一个一个去试
        for (k = i; k <= j; k++) {
            if (k * k <= x && (k + 1) * (k + 1) > x) {
                break;
            }
        }
        return k;
    }
};

全部评论

相关推荐

牛客刘北:如果暑期实习是27届的话,你要晚一年才会毕业,企业为什么会等你呢?要搞清时间逻辑呀!27届现在实习只能是在暑假实习,这是日常实习,不是暑期实习。所以多去投日常实习吧,暑期实习肯定不会要你的
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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