鱼C论坛

 找回密码
 立即注册
查看: 1875|回复: 0

[技术交流] 高精度加减法(C++)

[复制链接]
发表于 2019-7-4 12:50:08 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
高精度加法
#include<iostream>  
#include<string>  
#include<cmath>  
#include<cstdio>  
#include<cstring>  
#include<cstdlib>  
#include<iomanip>  
using namespace std;  
int main(){  
    //iomanip的语法(保留x位小数):cout<<fixed<<<setprecision(正整数)<<数;  
    char a1[1000],b1[1000];  
    int a[1000],b[1000],c[3000]={},lena,lenb,lenc,i,x,sum;  
    memset(a,0,sizeof(a));  
    memset(b,0,sizeof(b));  
    memset(c,0,sizeof(c));  
    gets(a1);  
    gets(b1);  
    lena=strlen(a1);  
    lenb=strlen(b1);  
    for(i=0;i<=lena-1;i++){  
        a[lena-i]=a1[i]-48;  
    }  
    for(i=0;i<=lenb-1;i++){  
        b[lenb-i]=b1[i]-48;  
    }  
    lenc=1;  
    x=0;  
    while(lenc<=lena||lenc<=lenb){  
        sum=a[lenc]+b[lenc]+x;  
        c[lenc]+=sum;  
        x=c[lenc]/10;  
        c[lenc]%=10;  
        lenc++;  
    }  
    c[lenc]=x;  
    if(c[lenc]==0){  
        lenc--;  
    }  
    for(i=lenc;i>=1;i--){  
        cout<<c[i];  
    }  
    cout<<endl;  
    return 0;  
} 
高精度减法
#include<iostream>  
#include<string>  
#include<cmath>  
#include<cstdio>  
#include<cstring>  
#include<cstdlib>  
#include<iomanip>  
using namespace std;  
int main(){  
    //iomanip的语法(保留x位小数):cout<<fixed<<<setprecision(正整数)<<数;  
    char n[1000],n1[1000],n2[1000];  
    int a[1000],b[1000],c[1000]={},lena,lenb,lenc,i;  
    memset(a,0,sizeof(a));  
    memset(b,0,sizeof(b));  
    memset(c,0,sizeof(c));  
    gets(n1);  
    gets(n2);  
    if(strlen(n1)<strlen(n2)||(strlen(n1)<strlen(n2)&&strcmp(n1,n2)<0)){  
        strcpy(n,n1);  
        strcpy(n2,n);  
        cout<<"-";  
    }  
    lena=strlen(n1);  
    lenb=strlen(n2);  
    for(i=0;i<=lena-1;i++){  
        a[lena-i]=int(n1[i]-'0');  
    }  
    for(i=0;i<=lenb-1;i++){  
        b[lenb-i]=int(n2[i]-'0');  
    }  
    i=1;  
    while(i<=lena||i<=lenb){  
        if(a[i]<b[i]){  
            a[i]+=10;  
            a[i+1]--;  
        }  
        c[i]=a[i]-b[i];  
        i++;  
    }  
    lenc=i;  
    while(c[lenc]==0&&lenc>1){  
        lenc--;  
    }  
    for(i=lenc;i>=1;i--){  
        cout<<c[i];  
    }  
    cout<<endl;  
    return 0;  
}  

这是代码,我怕太耗内存,就直接写上去了。。。

                               
登录/注册后可看大图

本帖被以下淘专辑推荐:

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-16 01:44

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表