2010 哈尔滨网络预选赛 1003解题报告

这道题其实可以转化为开方一个很大的数。这道题由于是求x使得x*x <= n < (x+1)*(x+1)的值,那么其实我们n的平方根就是居于x和x+1之间,但是这道题只是求x的值,也就是说只需要求一个近似值。如果我们从1开始递增的去测试,这道题不用想肯定是超时的,那么我们怎么很快的估算个x的值的平方非常接近于n呢?

求一个大数的平方根,在网上有模板算法的!但是基本上都是c/c++的,而且基本上都是求的一个高精度(double或者BigDecimal)的值,这道题本身是不需要求小数点后面的精度的,所以这些算法不一定适合。

其实我们很容易发现一个数的平方根肯定是小于这个数的一半,一半一半于是我们可以想到二分求解,怎么二分个发呢?那么我就带大家看看我的二分法吧!呵呵。。。经过测试,AC时间比我在网上找到的快很多!

你可能感兴趣的:(网络)