高精度运算专题2-减法运算(The subtraction operation)
这个专题呢,我就来讲讲高精度的减法,下面是三个计算减法的函数,第一个函数是char类型的,要对字符串进行数字转换,而第二个是两个int类型的数组,不用转换成数字,第三个则更为优化,用a数组-b数组放回数组a里面
函数1思路:要先把char类型的转换成int类型的数,直接每个数-‘0’就可以实现把char类型的转换成int类型的了。
①记录数组a、数组b、数组c的长度,放到第一位
②比较数组a和数组b的大小(长度长的大),如果大,交换也
③从前往后扫描数组a和数组b,每一位相减,如果数组a中的那一位<数组b中的那一位,就要借位(十位加十),再相减,存入数组c
注释:最后返回的ans是数组a与b的大小,-1则小,0则等,1则大
代码如下:
int sub(char strA[],char strB[],int c[])
//两个高精度的正整数a、b,计算a-b,结果放在c。
//c>0返回1;c==0返回0,c<0返回-1
{
char t[MaxLength];
int a[MaxLength]={},b[MaxLength]={};
int ans=,i;
int lenA,lenB,lenC,temp;
memset(c,,sizeof(c));
lenA=strlen(strA);
lenB=strlen(strB);
if( lenA<lenB || ( lenA==lenB && strcmp(strA,strB)< ) )
{
strcpy(t,strA);
strcpy(strA,strB);
strcpy(strB,t);
ans=-;
}
else if(strcmp(strA,strB)==)
{
ans=;
c[]=;
return ans;
}
init(strA,a);//从低位到高位存储
init(strB,b);//从低位到高位存储
i=;
while(i<=a[]||i<=b[])
{
if(a[i]<b[i])//借位
{
a[i]+=;
a[i+]--;
}
c[i]=a[i]-b[i];//注意:现在的C数组是从低位到高位存储的。
i++;
}
lenC=i;
while((c[lenC]==)&&(lenC>)) lenC--;//最高位的0不输出
c[]=lenC;
return ans;
}
函数2思路:这个减法函数和函数1差不多的,只是省去了把字符串转换成数字的部分
代码如下:
int sub2(int a[],int b[],int c[])// 输入高精度正整数a和b,计算a-b,结果存储在c。 c>0返回1;c==0返回0,c<0返回-1
{
int ans,i,temp,len;
int lenC;
memset(c,,sizeof(c)); ans=cmp(a,b);
if(ans==)
{
c[]=;
c[]=;
return ans;
}
else if(ans == -)
{//这里是表示a<b时要交换a和b
len=( a[]>b[] ? a[] : b[] );
for(i=;i<=len;i++)
{
temp=a[i];a[i]=b[i];b[i]=temp;
}
}
//下面开始做减法操作
i=;
while(i<=a[]||i<=b[])
{
if(a[i]<b[i])
{
a[i]+=;
a[i+]--;
}
c[i]=a[i]-b[i];//注意:现在的C数组是从低位到高位存储的。
i++;
}
lenC=i;
while((c[lenC]==)&&(lenC>)) lenC--;//消除高位无意义的0
c[]=lenC;
return ans;
}
函数3思路:这个函数优化了函数2,不用再开一个数组,大大地节省了时间
①首先得把数组a和数组b的长度分别存入a[0]、b[0]
②做减法,不够十要借位,十位数要加10,减去不够减的数
③最重要的一步:高位可能会有很多0,记得要消去
代码如下:
int sub3(int a[],int b[])//a=a-b 。 计算结果 a>0返回1;a==0返回0,a<0返回-1
{
int ans,i,temp,len;
int lenA;
ans=cmp(a,b);
if(ans==)
{
a[]=;
a[]=;
return ans;
}
else if(ans==-)
{
len=( a[]>b[] ? a[] : b[] );//这里是表示a<b时要交换a和b
for(i=;i<=len;i++)//排序
{
temp=a[i];
a[i]=b[i];
b[i]=temp;
}
}
//下面开始做减法操作
i=;
while(i<=a[]||i<=b[])
{
if(a[i]<b[i])//借位
{
a[i]+=;
a[i+]--;
}
a[i]=a[i]-b[i];//注意:现在的a数组是从低位到高位存储的。
i++;
}
lenA=i;
while((a[lenA]==)&&(lenA>)) lenA--;//消除高位无意义的0
a[]=lenA;
return ans;
}
函数4思路:这个函数优化了函数3,a=a-b,a>0返回1,a==0返回0,a<0返回-1,不过这个地方默认a>=b,主要是用于除法的操作过程
代码如下:
int sub4(int a[],int b[])//a=a-b 。a>0返回1,a==0返回0,a<0返回-1,不过这个地方默认a>=b,主要是用于除法的操作过程
{
int ans,i,temp,len;
int lenA; ans=cmp(a,b);
if(ans==)
{
a[]=;
a[]=;
return ans;
}
else if(ans==)
{
//下面开始做减法操作
i=;
while(i<=a[])
{
if(a[i]<b[i])
{
a[i]+=;
a[i+]--;
}
a[i]=a[i]-b[i];//注意:现在的a数组是从低位到高位存储的。
i++;
}
lenA=i;
while((a[lenA]==)&&(lenA>)) lenA--;//消除高位无意义的0
a[]=lenA;
}
return ans;
}
高精度运算专题2-减法运算(The subtraction operation)的更多相关文章
- 高精度运算专题3-乘法运算(The multiplication operation)
这个专题呢,我就来讲讲高精度的乘法,下面是三个计算乘法的函数,第一个函数是char类型的,要对字符串进行数字转换,而第二个是两个int类型的数组,不用转换成数字,第三个则更为优化,用a数组-b数组放回 ...
- 高精度运算专题1-加法运算(The addition operation)
这个专题呢,我就来讲讲高精度的加法,下面是一个计算加法的函数(用数组a加上数组b结果存到数组c里面). 思路:先测一下数组a和数组b的长度,分别放到a[0].b[0]里面去,再从第二位开始相加,记得满 ...
- 高精度运算专题-输出函数与字符串转数字函数(Output function and the string to number function)
输出函数:这个函数别看它小,但浓缩的都是精华啊 作用:对于高精度的数组进行倒序输出 思路:首先从被传入的数组第一位开始,一直往前扫输出就可以了(i--) 注释:因为每个数组的第一位是用来存储这个数组的 ...
- [code]高精度运算
数组存储整数,模拟手算进行四则运算 阶乘精确值 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 #includ ...
- 系统的讲解 - PHP 浮点数高精度运算
目录 概述 浮点数运算的"锅" 任意精度数学函数 常用数值处理方案 扩展 小结 概述 记录下,工作中遇到的坑 ... 关于 PHP 浮点数运算,特别是金融行业.电子商务订单管理.数 ...
- #C++初学记录(高精度运算)(加法)
高精度运算 不管是int还是double亦或者long long ,这些定义变量都有数据范围的一定限制,在计算位数超过十几位的数,也就是超过他们自身的数据范围时,不能采用现有类型进行计算,只能自己通过 ...
- ICPC Asia Nanning 2017 F. The Chosen One (高精度运算)
题目链接:The Chosen One 比赛链接:ICPC Asia Nanning 2017 题意 \(t\) 组样例,每组给出一个整数 \(n(2\le n\le 10^{50})\),求不大于 ...
- 算法模板 - C++ 高精度运算
C++算法板子 高精度 高精度推荐用python来写,python有大整数,这里写的是关于C++的高精度运算模板 1.高精 * 低精 #include <iostream> #includ ...
- Digital Root - SGU 118(高精度运算)
题目大意:有K组测试数据,然后每组有N个正整数,A1,A2,A3.....An,求出 A1 + A1*A2 + A1*A2*A3 + .......A1*A2*...An 的数根. 分析:有个对9取余 ...
随机推荐
- CodeForces 676D Theseus and labyrinth
最短路. $dis[i][j][k]$记录到点$(i,j)$,门的状态为$k$时的最短路.转移的时候有$8$种方案,即直接走向周围四个点,或者进行旋转.比较烦的是判断两个相邻的点在状态$k$下是否连通 ...
- C# 语言规范_版本5.0 (第14章 枚举)
1. 枚举 枚举类型 (enum type) 是一种独特的值类型(第 4.1 节),它用于声明一组命名的常量. 下面的示例 enum Color { Red, Green, Blue } 声明一个名为 ...
- struts2查询的数据的存放
当我们查询数据的时候,把它存放到一个位置.以供页面显示. 1:使用***Map取代内置对象存放 public String query(){ ActionContext.getContext().pu ...
- EntityFramework批量Insert
先说解决办法:使用SqlBulkCopy. 然后问题是:这个和EF没有半点关系,还要拼DataSet. 再是解决办法:你可以自己封装一个,也可以使用人家写好的 EntityFramework.Bulk ...
- iOS 隐藏导航栏 隐藏状态栏
1导航栏 self.navigationController.navigationBarHidden = YES; 2 状态栏 [[UIApplication sharedApplication] s ...
- fbset视频参数说明
在机器上输入:fbset mode "1280x720-55" # D: 67.504 MHz, H: 40.961 kHz, V: 54.907 Hz geometry 128 ...
- StackExchange.Redis 基本使用 (一) (转)
StackExchange.Redis下载地址: https://github.com/StackExchange/StackExchange.Redis/blob/master/Docs/Basic ...
- boolean attribute(布尔值属性) attribute vs property
boolean attribute(布尔值属性) boolean attribute HTML - Why boolean attributes do not have boolean val ...
- date,datetime,timestamp 的区别
date 表示年月日,如YY-MM-DD datetime 表示年月日和时间信息,如YY-MM-DD HH:MM:SS datestamp 和datetime表示的信息相同,但时间范围不同 时间范围 ...
- java 枚举类型和数据二进制等问题思考
.以下代码的输出结果是什么? int X=100; int Y=200; System.out.println("X+Y="+X+Y); System.out.println(X+ ...