c语言大数加法

本文介绍如何在C语言中处理大数加法,特别是涉及浮点数时,由于C语言的标准类型限制,需要将数字作为字符串处理。通过逐位相加的方法,实现了包括整数和小数部分的浮点数相加。具体实现中,先处理小数部分,从字符串末尾开始累加并处理进位,然后处理整数部分,同样从末尾开始累加并考虑高位补零。最后,将结果字符串反转得到正确答案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

c语言中int类型通常为32位,double类型为64,但不管多少位,能表达的数据还是有限的。对于超大数据的加法,如果通过转换为实际int或double类型值肯定是不行的,这时就需要考虑使用字符串方式,逐位相加来实现大数加法。

遇到一个问题,描述如下

题目描述
求2个浮点数相加的和

题目中输入输出中出现浮点数都有如下的形式:
P1P2…Pi.Q1Q2…Qj
对于整数部分,P1P2…Pi是一个非负整数
对于小数部分,Qj不等于0

关于输入
第1行是测试数据的组数n,每组测试数据占2行,分别是两个加数。每组测试数据之间有一个空行,每行数据不超过100个字符

关于输出
n行,每组测试数据有一行输出是相应的和。输出保证一定是一个小数部分不为0的浮点数

例子输入
2
0.111111111111111111111111111111
0.111111111111111111111111111111

10000000.655555555555555555555555555555
1.444444444444444444444444444445
例子输出
0.222222222222222222222222222222
10000002.1

浮点数包含整数与小数部分,小数部分需要补齐低位,而整数部分需要补齐高位。
所以计算小数相加时,从字符串末尾开始遍历,处理累加,并用变量flag保存进位标识。这里还要处理如果小数相加后末尾为0部分需要截取掉。最后返回flag进位标识,用于计算整数部分。

int decimalAdd(char *str1, char *str2, char *str3)
{
   
   
    int l1 = (str1 == NULL ? 0 : strlen(str1));
    int l2 = (str2 == NULL ? 0 : strlen(str2));
    int flag = 0; // 是否进位
    int i = l1 > l2 ? l1 : l2;
    int j = 0;
    while (i > 0) {
   
   
        int t = flag;
        if (i <= l1)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

togolife

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值