高精度除法的实现
高精度除法与高精度加法的定义、前置过程都是大致相同的,如果想了解具体内容,可以移步至我的这篇博客:高精度加法计算的实现
在这里就不再详细讲解,只讲解主体过程qwq
主体过程
高精度除法的原理和小学学习的竖式除法是一样的。
概括来说,假如被除数长度为,除数长度为
,为了减少冗余运算,我们从
从后往前开始计算,将被除数与除数相对应的每一位相(整)除,实际上这一步可以看作一个逐次减法的过程,然后存进商的对应位置上,再将余数乘
并放进下一位。
用高精度计算,先除百位,将
减去
一次后变为
,小于
,所以将
存入百位,将
存入十位;
再除十位,将减去
三次后变为
,小于
,所以将
存入十位,将
存入个位;
最后除个位,将减去
八次后变为
,小于
,所以将
存入个位,将
存入余数数组。
其实,高精度除法按理来说不需要反转存储,正序存储会更方便,但大部分题目,如果需要高精度除法去做,那么很有可能也需要其他的高精度计算,为了统一,我们还是使用反转存储。
接下来,我们这里实现一个函数,它判断了被除数以下标为最低位,是否可以再减去除数而保持非负。这个函数分为三部分:
- 被除数剩余的部分比除数长,这个情况下最多多出 1 位,函数返回真。
- 如第一步判断为假,就说明被除数与除数一样长,那我们就从高位到低位,逐位比较:如果被除数当前位比除数当前位大,函数返回真;反之,函数返回假。
- 如第二步也判断为假,就说明被除数与除数相等,相等的情形下也是可行的,函数返回真。
下面给出高精度除法的代码:
bool big(int a[],int b[],int low,int L){
if(a[low+L]!=0) return 1;
for(int i=L-1;i>=0;--i){
if(a[low+i]>b[i])
return 1;
if(a[low+i]0;la--){
if(a[la-1]!=0)
break;
}
for(lb=L-1;lb>0;lb--){
if(b[lb-1]!=0)
break;
}
if(lb==0) return;
for(int i=0;i=0;i--){
while(big(d,b,i,lb)){
for(int j=0;j=0;i--)
cout
免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们,邮箱:ciyunidc@ciyunshuju.com。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!

