大数加法(A + B Problem Plus)问题
解题思路
两个⼤数可以⽤数组来逐位保存,然后在数组中逐位进⾏相加,再判断该位相加后是否需要进位。为了⽅便计算,可以把数字的低位放到数组的前面,高位放在后面。
样例输入
3
18 22
56 744
53234673473 7544645548767
样例输出
Case 1:
18 + 22 = 40
Case 2:
56 + 744 = 800
Case 3:
53234673473 + 7544645548767 = 7597880222240
代码实现
#include<stdio.h>
#include<string.h>
#define NUM_MAX 1000 // 大数的最大位数
#define CASE_MAX 100 // 示例的最大值
/*
大数加法
参数:
str1为第一个大数,用字符数组保存
str2为第二个大数
sum数组保存相加的结果 即:str1+str2=sum
返回值:返回数组sum的有效长度,即计算结果的位数
*/
void Add(char* numA, char* numB, int* sum)
{
int k = 0;
int l = 0;
int array[NUM_MAX] = {0};
int lenA = strlen(numA); // 计算数组numA的长度,即数A的位数
int lenB = strlen(numB); // 计算数组numB的长度,即数B的位数
int maxLen = lenA > lenB ? lenA : lenB; // 取两个数中大的位数
// 将numA字符数组的数字字符转换为整型数字,且逆向保存在整型数组sum中,即低位在前,高位在后
for (int i = lenA - 1; i >= 0; i--)
{
sum[k++] = numA[i] - '0';
}
// 转换第二个数
for (int j = lenB - 1; j >= 0; j--)
{
array[l++] = numB[j] - '0';
}
// 两个数相加
for (int i = 0; i <= maxLen; i++)
{
sum[i] += array[i]; // 两个数从低位开始相加
if (sum[i] > 9) // 判断是否有进位
{
sum[i] %= 10;
sum[i+1]++;
}
}
if (sum[maxLen] != 0) // 判断最高位是否有进位
{
maxLen++;
}
// 逆向输出求和的结果
for (int i = maxLen - 1; i >= 0; i--)
{
printf("%d", sum[i]);
}
printf("\n");
}
int main()
{
int caseNum = 0;
scanf("%d", &caseNum);
if (caseNum < 1 || caseNum > 100)
{
return 1;
}
char strA[CASE_MAX][NUM_MAX] = {0};
char strB[CASE_MAX][NUM_MAX] = {0};
for (int i = 0; i < caseNum; i++)
{
scanf("%s%s", strA[i], strB[i]);
}
for (int i = 0; i < caseNum; i++)
{
int sum[NUM_MAX] = {0}; // 存放计算的结果,低位在前,高位在后,即sum[0]是低位
printf("Case %d:\n", i + 1);
printf("%s + %s = ", strA[i], strB[i]);
Add(strA[i], strB[i], sum);
// 每个样例之间输出空行
if(i < caseNum)
{
printf("\n");
}
}
return 0;
}
个人主页:
大数加法(A + B Problem Plus)问题的更多相关文章
- A + B Problem II(大数加法)
http://acm.hdu.edu.cn/showproblem.php?pid=1002 A + B Problem II Time Limit: 2000/1000 MS (Java/Other ...
- A + B Problem II 大数加法
题目描述: Input The first line of the input contains an integer T(1<=T<=20) which means the number ...
- 大数加法~HDU 1002 A + B Problem II
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1002 题意: 数学题,A+B; 思路,这个数非常大,普通加法一定会超时,所以用大数加法.大数加法的基 ...
- hdu 1002 A + B Problem II【大数加法】
题目链接>>>>>> 题目大意:手动模拟大数加法,从而进行两个大数的加法运算 #include <stdio.h> #include <strin ...
- 玲珑杯1007-A 八进制大数加法(实现逻辑陷阱与题目套路)
题目连接:http://www.ifrog.cc/acm/problem/1056 DESCRIPTION Two octal number integers a, b are given, and ...
- 【大数加法】POJ-1503、NYOJ-103
1503:Integer Inquiry 总时间限制: 1000ms 内存限制: 65536kB 描述 One of the first users of BIT's new supercompu ...
- hdu_1041(Computer Transformation) 大数加法模板+找规律
Computer Transformation Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/ ...
- Hat's Fibonacci(大数加法+直接暴力)
题目连接:http://acm.hdu.edu.cn/showproblem.php?pid=1250 hdu1250: Hat's Fibonacci Time Limit: 2000/1000 M ...
- ZZNU 2125:A + B 普拉斯(傻逼题+大数加法)
2125: A + B 普拉斯 时间限制: 1 Sec 内存限制: 128 MB 提交: 94 解决: 28 [提交] [状态] [讨论版] [命题人:admin] 题目描述 "别人总说 ...
随机推荐
- 阶段3 1.Mybatis_04.自定义Mybatis框架基于注解开发_2 回顾自定义mybatis的流程分析
- 一:flask-第一个flask程序
安装flask:pip install flask,或者pycharm安装 最小模型 访问 后台:
- 2018.03.29 python-pandas 数据透视pivot table / 交叉表crosstab
#透视表 pivot table #pd.pivot_table(data,values=None,index=None,columns=None, import numpy as np import ...
- 【MM系列】SAP 各种冲销凭证
公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[MM系列]SAP 各种冲销凭证 前言部分 ...
- sentos7网卡改名
一.已经装好系统CentOS7修改网卡为eth0 1. 修改网卡配置文件[root@localhost ~]# mv /etc/sysconfig/network-scripts/ifcfg-ens3 ...
- 应用安全 - 编程语言漏洞 - PHP语言漏洞汇总
CVE-2019-11043 Date: 类型: 远程代码执行 前置条件: Nginx + fastcgi + php-fpm 配置文件信息如下: location ~ [^/]\.php(/|$) ...
- 【Windows Server存储】windows文件系统
windows文件系统 弹性文件系统(ReFS) 无检查磁盘,Windows 8或Windows Server 2012以上运行. 参考资料表明,这是一个失败的文件系统,以后将不会商用. 参考资料:h ...
- Java合并数组的实现方式
String[] aa = {"11","22","33"};String[] bb = {"44","55& ...
- 文档压缩 | gzip、bzip2、xz
6.文档的压缩与打包 Linux下常见后缀名所对应的的压缩工具 .gz 表示由gzip压缩工具压缩的文件 .bz2 表示由bzip2压缩工具压缩的文件 .tar 表示由tar打包程序打包的文件(tar ...
- 【查阅】mysql配置文件/参数文件重要参数笔录(my.cnf)
持续更新,积累自己对参数的理解 [1]my.cnf参数 [client]port = 3306socket = /mysql/data/3306/mysql.sockdefault-character ...