原理:
1.从个位起向左每隔两位为一节,若带有小数从小数点起向右每隔两位一节,用“,”号将各节分开;
2.求不大于左边第一节数的完全平方数,为“商”;
3.从左边第一节数里减去求得的商,在它们的差的右边写上第二节数作为第一个余数;
4.把商乘以20,试除第一个余数,所得的最大整数作试商(如果这个最大整数大于或等于10,就用9或8作试商);
5.用商乘以20加上试商再乘以试商。如果所得的积小于或等于余数,就把这个试商写在商后面,作为新商;如果所得的积大于余数,就把试商逐次减小再试,直到积小于或等于余数为止;
6.用同样的方法,继续求。
package test002;
public class test003 {
public static void main(String[] args)
{
int[] math=new int[20];
int[] re=new int[21];
int temp,wt; //temp用来存放余数,wt用来存放商
math[0]=2;
int i=0;
while(i*i<=math[0]){
i++;
}
re[0]=i-1;
wt=re[0]*1;
temp=math[0]-re[0]*re[0];
int m=1;
for(int k=re.length-1;k>0;k--){
temp*=100;
for(int j=0;j<10;j++){
if((20*wt+j)*j<=temp){
re[m]=j;
continue;
}
}
temp-=(20*wt+re[m])*re[m];
wt=wt*10+re[m];
m++;
}
System.out.println(re);
}
}