之前已经完毕了大整数的表示、绝对值的比較大小、取负值、加减法运算以及乘法运算。

详细见前两篇博客(自己动手写Java * )。

这里加入除法运算。

另外看到作者Pauls Gedanken在blog(http://paul-ebermann.tumblr.com/post/6312290327/big-numbers-selfmade-part-2-14-conversion-from)中的转换十进制数到大整数的方法,这里一并列出。

除法

除法使用经典的除法法则,可是有几个须要注意的问题,以下列出。

1,除数是0的问题;

2。两者相等,输出1余数是被除数;

3。除数比較大,直接输出0。余数是被除数

4,子数组长度和除数数组长度相等或者大1。相等时候结果由子数组第一位除以除数第一位决定,

大1时候结果通过子数组头两位除以除数第一位决定

5,判定结果第一位是否为0.

我们看下简单的图演示样例子。看看除法的详细操作

	/*
* 除法
*/ public DecimalBig Divide(DecimalBig that)
{
if (that.Compare(Zero)==0)
throw new IllegalArgumentException("Divided by 0!");
if (this.Abscompare(that)==-1)
return Zero;
if (this.Abscompare(that)==0)
return One; int thislength=this.digits.length;
int thatlength=that.digits.length; int[] mulres=new int[thatlength];
System.arraycopy(this.digits, 0, mulres, 0, thatlength);
int digitdivide=0;
int[] result=new int[thislength-thatlength+1]; for (int i=0; i<thislength-thatlength;i++)
{
if (Arraycompare(mulres,that.digits)==-1)
{
digitdivide=0;
} else
{
if (mulres.length==that.digits.length)
digitdivide=mulres[0]/that.digits[0];
else{
long firtwei=(long)mulres[0]*Radix+mulres[1];
digitdivide=(int)firtwei/that.digits[0]; } int[] temp=Multiplyint(that.digits, digitdivide); if (Arraycompare(mulres,temp)==-1){
digitdivide-=1;
temp=Substract(temp,that.digits);
}
mulres=Substract(mulres, temp);
} result[i]=digitdivide;
if (mulres.length==1&&mulres[0]==0){
mulres[0]=this.digits[i+thatlength];
}else{
int[] temp2=new int[mulres.length+1];
System.arraycopy(mulres, 0, temp2, 0, mulres.length);
temp2[mulres.length]=this.digits[i+thatlength];
mulres=temp2;
}
} if (Arraycompare(mulres,that.digits)==-1)
{
digitdivide=0;
} else
{
if (mulres.length==that.digits.length)
digitdivide=mulres[0]/that.digits[0];
else{
long firtwei=(long)mulres[0]*Radix+mulres[1];
long ttt=firtwei/that.digits[0];
digitdivide=(int) ttt;
} int[] temp=Multiplyint(that.digits, digitdivide); if (Arraycompare(mulres,temp)==-1){
digitdivide-=1;
temp=Substract(temp,that.digits);
}
mulres=Substract(mulres, temp);
} /*
* 最后的mulres就是余数。
*/ result[thislength-thatlength]=digitdivide;
/*
* 去掉首位的零
*/
int i=0;
while(i<result.length&&result[i]==0)
i++;
//截取非零项
int[] temp = new int[result.length-i];
System.arraycopy(result, i, temp, 0, result.length-i);
result = temp; return new DecimalBig(1, result);
} /*
* 除法余数
*/ public DecimalBig DivideReminder(DecimalBig that)
{
if (that.Compare(Zero)==0)
throw new IllegalArgumentException("Divided by 0!");
if (this.Abscompare(that)==-1)
return this;
if (this.Abscompare(that)==0)
return Zero; int thislength=this.digits.length;
int thatlength=that.digits.length; int[] mulres=new int[thatlength];
System.arraycopy(this.digits, 0, mulres, 0, thatlength);
int digitdivide=0;
int[] result=new int[thislength-thatlength+1]; for (int i=0; i<thislength-thatlength;i++)
{
if (Arraycompare(mulres,that.digits)==-1)
{
digitdivide=0;
} else
{
if (mulres.length==that.digits.length)
digitdivide=mulres[0]/that.digits[0];
else{
long firtwei=(long)mulres[0]*Radix+mulres[1];
digitdivide=(int)firtwei/that.digits[0]; } int[] temp=Multiplyint(that.digits, digitdivide); if (Arraycompare(mulres,temp)==-1){
digitdivide-=1;
temp=Substract(temp,that.digits);
}
mulres=Substract(mulres, temp);
} result[i]=digitdivide;
if (mulres.length==1&&mulres[0]==0){
mulres[0]=this.digits[i+thatlength];
}else{
int[] temp2=new int[mulres.length+1];
System.arraycopy(mulres, 0, temp2, 0, mulres.length);
temp2[mulres.length]=this.digits[i+thatlength];
mulres=temp2;
}
} if (Arraycompare(mulres,that.digits)==-1)
{
digitdivide=0;
} else
{
if (mulres.length==that.digits.length)
digitdivide=mulres[0]/that.digits[0];
else{
long firtwei=(long)mulres[0]*Radix+mulres[1];
long ttt=firtwei/that.digits[0];
digitdivide=(int) ttt;
} int[] temp=Multiplyint(that.digits, digitdivide); if (Arraycompare(mulres,temp)==-1){
digitdivide-=1;
temp=Substract(temp,that.digits);
}
mulres=Substract(mulres, temp);
} /*
* 最后的mulres就是余数。 */ return new DecimalBig(1, mulres);
}

十进制转换

引自Pauls Gedanken的方法

    /**引用
* Pauls Gedanken在bloghttp://paul-ebermann.tumblr.com/post/6312290327/big-numbers-selfmade-part-2-14-conversion-from
* 中的方法
* creates a DecimalBigInt from a decimal representation.
* @param decimal a string of decimal digits.
* @throws NumberFormatException if the number is not in
* correct decimal format, e.g. if it contains any characters
* outside of 0..9.
*/
public static DecimalBig valueOf(int si, String decimal) {
int decLen = decimal.length();
int bigLen = (decLen-1) / Radix_Decimal_length + 1;
// length of first block
int firstSome = decLen - (bigLen-1) * Radix_Decimal_length;
int[] digits = new int[bigLen];
for(int i = 0; i < bigLen ; i++) {
String block =
decimal.substring(Math.max(firstSome + (i-1)*Radix_Decimal_length, 0),
firstSome + i *Radix_Decimal_length);
digits[i] = Integer.parseInt(block);
}
return new DecimalBig(si, digits);
}

自己动手写Java大整数《3》除法和十进制转换的更多相关文章

  1. [JVM] - 一份<自己动手写Java虚拟机>的测试版

    go语言下载 配置GOROOT(一般是自动的),配置GOPATH(如果想自己改的话) 参照<自己动手写Java虚拟机> > 第一章 指令集和解释器 生成了ch01.exe文件 这里还 ...

  2. 自己动手写java 字节流输入输出流

    数据流是一串连续不断的数据的集合,就象水管里的水流,在水管的一端一点一点地供水,而在水管的另一端看到的是一股连续不断的水流.   "流是磁盘或其它外围设备中存储的数据的源点或终点." ...

  3. 关于Java大整数是否是素数

    题目描述 请编写程序,从键盘输入两个整数m,n,找出等于或大于m的前n个素数. 输入格式: 第一个整数为m,第二个整数为n:中间使用空格隔开.例如: 103 3 输出格式: 从小到大输出找到的等于或大 ...

  4. 自己动手写java锁

    1.LockSupport的park和unpark方法的基本使用,以及对线程中断的响应性 LockSupport是JDK中比较底层的类,用来创建锁和其他同步工具类的基本线程阻塞原语.java锁和同步器 ...

  5. JAVA大整数傻瓜入门

    http://blog.csdn.net/skiffloveblue/article/details/7032290..先记着

  6. java 中整数类型的进制转换

    int a=10; Integer.toBinaryString(a); //转换成2进制Integer.toOctalString(a);  //转换成8进制Integer.toHexString( ...

  7. [大整数乘法] java代码实现

    上一篇写的“[大整数乘法]分治算法的时间复杂度研究”,这一篇是基于上一篇思想的代码实现,以下是该文章的连接: http://www.cnblogs.com/McQueen1987/p/3348426. ...

  8. Coefficient Computation (大整数、Java解决)

    Coefficient Computation UVALive8265 题意:计算组合数C(n,k)的值并将值按给定的进制输出. 思路:Java大整数类硬上. PS:刚刚学完Java的大整数类,结果却 ...

  9. COJ 1211 大整数开平方

    手写求大整数开根号所得到的值,具体计算过程参考别人的资料,最后利用java的大整数得到答案 别人博客链接:http://www.cnblogs.com/Rinyo/archive/2012/12/16 ...

随机推荐

  1. javaTemplates-学习笔记一

    第一步,下载Java运行环境-JDK JDK -'1.8.0_25'[附链接地址] 安装JDK配置环境 安装好jdk,然后配置环境变量.不同系统配置环境变量百度Google之,附上WIN8配置方法[J ...

  2. 在sqlite中使用索引

    出处: 网络 1)Sqlite不支持聚集索引,android默认需要一个_id字段,这保证了你插入的数据会按“_id”的整数顺序插入,这个integer类型的主键就会扮演和聚集索引一样的角色.所以不要 ...

  3. MVC中Filter拦截问题记录之重定向陷阱

    出错环境:被拦截的页面中使用了未实例化的对象,比如只有登录后才有的UserInfor对象. 理想中:浏览器请求页面时,会被Filter拦截,然后重定向到指定页面: 实际现象:将断点打入Filter中, ...

  4. Python 标识符

    Python 标识符 在python里,标识符有字母.数字.下划线组成. 在python中,所有标识符可以包括英文.数字以及下划线(_),但不能以数字开头. python中的标识符是区分大小写的. 以 ...

  5. Web存储(Web Storage)介绍

    Web存储即在客户端存储数据. 在没有Web Storage之前,是通过cookie来在客户端存储数据的.但是由于 浏览器能存cookie数比较少.如IE8,Firefox,opera每个域可以保存的 ...

  6. Oracle SQL CPU占用高

    Oracle数据库经常会遇到CPU利用率很高的情况,这种时候大都是数据库中存在着严重性能低下的SQL语句,这种SQL语句大大的消耗了CPU资源,导致整个系统性能低下.当然,引起严重性能低下的SQL语句 ...

  7. BaaS with Kinvey and Delphi 10.1 Berlin

    In this article I will show you how to connect yourdesktop and mobile applications to a mobile backe ...

  8. iOS 监听键盘变化

    //将要显示键盘 [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(willShowKeyboard: ...

  9. iOS实践02

    第二天了,上了一天课,软件测试.数据挖掘.概率论,晚上了才有时间捣鼓捣鼓程序. 今天只是简单的做了一点.觉得自己思考的写不出来,只能简单的写一个过程,不像第一次写这个,少了很多思考的. 1.完善tab ...

  10. C++ typedef

    C++ typedef 作用:用来定义类型的同义词,用作类型的说明符. 用法:typedef typeName myTypeName; 使用目的:1. 为了隐藏特定类型的实现,强调使用类型的目的.2. ...