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

本文介绍了一种高效的大数平方根算法实现,采用二分法快速逼近目标值,相较于传统方法,该算法在保证准确性的前提下显著提升了计算速度。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

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

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

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值