高精度数应用

1.用一个数组表示高精度数

1.字符串接收数据

2.字符串中的各位字符转换为对应十进制数

3.按十进制位的顺序存储到一个数组中

#include<stdio.h>
#include<string.h>
int main()
{
    int a[100]={0};
    int i,len;
    char s[100]; //'1234567890123456'
    scanf("%s",s);
    len=strlen(s);
    for(i=0;i<=len-1;i++)
    {
        a[i]=s[len-i-1]-'0';//数组从右到左存储高精度正整数6543210987654321
    }
    return 0;
}

2.高精度正整数求和

//x和y按如上形式存储在数组a和数组b中,n1为x的位数,n2为y的位数
for(i=0;i<(n1>n2?n1:n2);i++)
{
    a[i]=a[i]+b[i];
    if(a[i]>9)
    {
        a[i]=a[i]-10;
        a[i+1]++;
    }
}

3.高精度正整数(x>y)相减

for(i=0;i<n1;i++)
    {
        a[i]=a[i]-b[i];
        if(a[i]<0)
        {
            a[i]=a[i]+10;
            a[i+1]--;
        }
    }
    for(i=n1-1;i>=0;i--)
    {
        if(i==n1-1&&a[i]==0)
        {
            //首位为0
        }
        else printf("%d",a[i]);
    }

4.高精度数乘的运算

LA为a的位数 LB为b的位数 乘积的位数上限为LA+LB

a[i]*b[j]的积累加到c[i+j]

对累加结果数组c作一次性进位


for(i=0;i<=LA-1;i++)
{
    for(j=0;j<=LB-1;j++)
    {
        c[i+j]=a[i]*b[j];
    }
}

for(i=0;i<LA+LB;i++)
{
    if(c[i]>=10)
    {
        c[i+1]=c[i]/10; //进几
        c[i]=c[i]%10;
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值