两点距离公式--平方根

/**
     * 求平方根
     * @param value 定义域
     * @return 值域
     
*/

    final 
public   static   int  sqrt( int  value)  {
        
int sqrt = 0;
        
for (int k = 0x100000; k != 0; k >>= 2{
            
int tmp = sqrt + k;
            sqrt 
>>= 1;
            
if (tmp <= value) {
                value 
-= tmp;
                sqrt 
+= k;
            }

        }

        
return sqrt;
    }

    
    
/**
     * 两点距离公式
     * 根据泰勒级数展开,取前三层,足够了。。
     * @param dx - x 方向相对距离
     * @param dy - y 方向相对距离
     * @return
     *  - 第三条边的长度。。
     
*/

    final 
public   static   int  fastSqrt( int  dx,  int  dy)  {
         dx 
= dx < 0 ? -dx : dx;
         dy 
= dy < 0 ? -dy : dy;
         
int dmin = dx < dy ? dx : dy;
         
return (dx + dy - (dmin >> 1- (dmin >> 2+ (dmin >> 4));
    }
 
 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值