java biginteger.zero_Java BigInteger 开方sqrt的实现

package com.swu.math;

import java.math.BigInteger;

public class Test

{

public static String sqrt(String num)

{

BigInteger b=new BigInteger(num);

//不用多解释了吧

if(b.compareTo(BigInteger.ZERO)<0)

return "不是正数";

String sqrt="0"; //开方结果

String pre="0"; //开方过程中需要计算的被减数

BigInteger trynum; //试商,开放过程中需要计算的减数

BigInteger flag;  //试商,得到满足要求减数的之后一个数

BigInteger twenty=new BigInteger("20"); //就是20

BigInteger dividend; ///开方过程中需要计算的被减数

int len=num.length(); //数字的长度

if(len%2==0) //长度为偶数

{

for(int i=0;i

{

dividend=new BigInteger(pre+num.substring(2*i,2*i+2));

for(int j=0;j<=9;++j)

{

trynum=twenty.multiply(new BigInteger(sqrt)).multiply(new BigInteger(j+"")).add(new BigInteger(j+"").multiply(new BigInteger(j+"")));

flag=twenty.multiply(new BigInteger(sqrt)).multiply(new BigInteger((j+1)+"")).add(new BigInteger((j+1)+"").multiply(new BigInteger((j+1)+"")));;

//满足要求的j使得试商与计算中的被减数之差为最小正数

if(trynum.subtract(dividend).compareTo(BigInteger.ZERO)<=0

&&flag.subtract(dividend).compareTo(BigInteger.ZERO)>0)

{

sqrt+=j;  //结果加上得到的j

pre=dividend.subtract(trynum).toString(); //更新开方过程中需要计算的被减数

break;

}

}

}

}

else //长度为奇数

{

for(int i=0;i

{

if(i==0) //奇数位被开方数首位特殊处理

dividend=new BigInteger(num.charAt(0)+"");

else

dividend=new BigInteger(pre+num.substring(2*i-1,2*i+1));

for(int j=0;j<=9;++j)

{

trynum=twenty.multiply(new BigInteger(sqrt)).multiply(new BigInteger(j+"")).add(new BigInteger(j+"").multiply(new BigInteger(j+"")));

flag=twenty.multiply(new BigInteger(sqrt)).multiply(new BigInteger((j+1)+"")).add(new BigInteger((j+1)+"").multiply(new BigInteger((j+1)+"")));;

//满足要求的j使得试商与计算中的被减数之差为最小正数

if(trynum.subtract(dividend).compareTo(BigInteger.ZERO)<=0

&&flag.subtract(dividend).compareTo(BigInteger.ZERO)>0)

{

sqrt+=j; //结果加上得到的j

pre=dividend.subtract(trynum).toString(); //更新开方过程中需要计算的被减数

break;

}

}

}

}

return sqrt.substring(1);

}

public static void main(String[] args)

{

System.out.println(MathTool.sqrt("1234567890123456789"));

System.out.println(Math.sqrt(1234567890123456789l));

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值