高精除高精
好了直接捞干的——————总而言之就是转化为高精-低精一直减,减啊减减到小于0只
但是这中间建议多写几个小函数,方便(dog)
这里还有一个注意就是虽然减的时候可以加啊加但是可能会超范围所及我们要写高精度加法————高精度加法2.0版需用下面代码辅助
void numcpy(int p[],int q[],int det){
for(int i=1;i<=p[0];i++){
q[i+det-1]=p[i];
}
q[0]=det+p[0]-1 ;
}
void chuhao(int a[],int b[],int c[]){
int i,temp[101];
c[0]=a[0]-b[0]+1;
for(i=c[0];i>0;i--){
memset(temp,0,sizeof(temp));
numcpy(b,temp,i);
while(compare(a,temp)>=0){
c[i]++;
jian(a,temp);
}
}
while(c[0]>0&&c[c[0]]==0){
c[0]--;
}
return;
}
顺道写的高精度加法
完整代码附上
#include<bits/stdc++.h>
using namespace std;
int a[101],b[101],c[101],d,i;
void init(int a[]){
string s;
cin>>s;
a[0]=s.length();
for(i=1;i<=a[0];i++){
a[i]=s[a[0]-i]-'0';
}
}
void print(int a[]){
int i;
if(a[0]==0){
cout<<0<<endl;
return;
}
for(i=a[0];i>0;i--){
cout<<a[i];
}
cout<<endl;
return;
}
int compare(int a[],int b[]){
int i;
if(a[0]>b[0]){
return 1;
}
if(a[0]<b[0]){
return -1;
}
for(i=a[0];i>0;i--){
if(a[i]>b[i]){
return 1;
}
if(a[i]<b[i]){
return -1;
}
}
return 0;
}
void jian(int a[],int b[]){
int flag=compare(a,b),i;
if(flag==0){
a[0]=0;
return;
}
if(flag==1){
for(i=1;i<=a[0];i++){
if(a[i]<b[i]){
a[i+1]--;
a[i]+=10;
}
a[i]-=b[i];
}
}
while(a[0]>0&&a[a[0]]==0){
a[0]--;
}
}
void numcpy(int p[],int q[],int det){
for(int i=1;i<=p[0];i++){
q[i+det-1]=p[i];
}
q[0]=det+p[0]-1 ;
}
void chuhao(int a[],int b[],int c[]){
int i,temp[101];
c[0]=a[0]-b[0]+1;
for(i=c[0];i>0;i--){
memset(temp,0,sizeof(temp));
numcpy(b,temp,i);
while(compare(a,temp)>=0){
c[i]++;
jian(a,temp);
}
}
while(c[0]>0&&c[c[0]]==0){
c[0]--;
}
return;
}
int main(){
memset(a,0,sizeof(a));
memset(b,0,sizeof(b));
memset(c,0,sizeof(c));
init(a);
init(b);
chuhao(a,b,c);
print(c);
return 0;
}