高精度加法(C++实现)
高精度加法
简介
用于计算含有超过一般变量存放不下的非负整数
高精度加法这个过程是模拟的小学竖式加法计算
步骤
以下有顺序之分
- 数组清零
- 输入
- 获取长度
- 逆置
- 字符型数字转成对应的整型数字
- 计算并输出
简单来看重要的步骤也就以下几步
- 清零
- 逆置
- 转换
- 相加计算(包含进位)
代码实现
逆置
因为数组存放的元素顺序与我们计算的顺序是相反的,在竖式计算中我们是将其右对齐(个位对个位,十位对十位,以此类推),而读取数字后的两个数组是左对齐的,因此我们要将里面的元素逆置
//参数:需要逆置的数组,数组长度
void invertElem(char s[], unsigned long n)
{
unsigned long len = n - 1;
for (int i = 0, j = len; i < j; i++, j--)
{
char temp = s[i];
s[i] = s[j];
s[j] = temp;
}
}
转换
为了方便计算和进位,我们需要将字符型的数字转化成实际数字
注意:这里的转换不是类型转换,例如字符类型8,我们要让它自减48,转化成ASCII码为8的对应的字符,存放元素的数组的类型并没有改变
转换必须在逆置之后。如果转换在前逆置在后,则逆置时分不清末尾的0是数字的一部分还是结束符转换后的数字
//参数:数组,长度
void charInt(char s[], unsigned long n)
{
for (int i = 0; i < n; i++)
s[i] -= 48;
}
相加
有了以上两个函数之后,我们就可以进行相加了,这里不多说,分析都在注释里,所以直接上代码
int main()
{
while (1)
{
char a[1024];
char b[1024];
char c[2049];
//这里必须将每一个元素都置为0,否则位数不同的数字相加时会乱掉
memset(a, 0, sizeof(a));
memset(b, 0, sizeof(b));
memset(c, 0, sizeof(c));
scanf("%s", a);
scanf("%s", b);
//长度获取要在转换之前
unsigned long len_a = strlen(a);
unsigned long len_b = strlen(b);
unsigned long max_len = len_a > len_b ? len_a : len_b;
//逆置
invertElem(a, len_a);
invertElem(b, len_b);
//转换
charInt(a, len_a);
charInt(b, len_b);
int carry = 0; //进位
//相加,核心步骤
//这里的i必须能取到max_len,最高位计算式可能会向前进一位
//比如99+1,原本最多两位,相加后得到了一个三位数
for (int i = 0; i <= max_len; i++)
{
c[i] = (carry + a[i] + b[i]) % 10;
carry = (carry + a[i] + b[i]) / 10;
}
int i;
//寻找第一个不为0的数字或全是0的情况况下找到最后一个0
//这是为了防止00+0之类的特殊情况,在这种情况发生时确保只输出一个0
for (i = max_len; i >= 1 && c[i] == 0; i--);
for (; i >= 0; i--)
printf("%d", c[i]);
printf("\n");
}
return 0;
}
完整代码
#include <iostream>
#include <string.h>
#include <math.h>
using namespace std;
//参数:需要逆置的数组,数组长度
void invertElem(char s[], unsigned long n)
{
unsigned long len = n - 1;
for (int i = 0, j = len; i < j; i++, j--)
{
char temp = s[i];
s[i] = s[j];
s[j] = temp;
}
}
void charInt(char s[], unsigned long n)
{
for (int i = 0; i < n; i++)
s[i] -= 48;
}
int main()
{
while (1)
{
char a[1024];
char b[1024];
char c[2049];
//这里必须将每一个元素都置为0,否则位数不同的数字相加时会乱掉
memset(a, 0, sizeof(a));
memset(b, 0, sizeof(b));
memset(c, 0, sizeof(c));
scanf("%s", a);
scanf("%s", b);
//长度获取要在转换之前
unsigned long len_a = strlen(a);
unsigned long len_b = strlen(b);
unsigned long max_len = len_a > len_b ? len_a : len_b;
//逆置
invertElem(a, len_a);
invertElem(b, len_b);
//转换
charInt(a, len_a);
charInt(b, len_b);
int carry = 0; //进位
//相加,核心步骤
//这里的i必须能取到max_len,最高位计算式可能会向前进一位
//比如99+1,原本最多两位,相加后得到了一个三位数
for (int i = 0; i <= max_len; i++)
{
c[i] = (carry + a[i] + b[i]) % 10;
carry = (carry + a[i] + b[i]) / 10;
}
int i;
//寻找第一个不为0的数字或全是0的情况况下找到最后一个0
//这是为了防止00+0之类的特殊情况,在这种情况发生时确保只输出一个0
for (i = max_len; i >= 1 && c[i] == 0; i--);
for (; i >= 0; i--)
printf("%d", c[i]);
printf("\n");
}
return 0;
}
高精度加法(C++实现)的更多相关文章
- NEFU 2016省赛演练一 F题 (高精度加法)
Function1 Problem:F Time Limit:1000ms Memory Limit:65535K Description You know that huicpc0838 has b ...
- java算法 蓝桥杯 高精度加法
问题描述 在C/C++语言中,整型所能表示的范围一般为-231到231(大约21亿),即使long long型,一般也只能表示到-263到263.要想计算更加规模的数,就要用软件来扩展了,比如用数组或 ...
- 用c++实现高精度加法
c++实习高精度加法 最近遇到一个c++实现高精度加法的问题,高精度问题往往十复杂但发现其中的规律后发现并没有那么复杂,这里我实现了一个整数的高精度加法,主要需要注意以下几点: 1:将所需输入的数据以 ...
- 高精度加法——经典题 洛谷p1601
题目背景 无 题目描述 高精度加法,x相当于a+b problem,[b][color=red]不用考虑负数[/color][/b] 输入输出格式 输入格式: 分两行输入a,b<=10^500 ...
- 高精度加法--C++
高精度加法--C++ 仿照竖式加法,在第一步计算的时候将进位保留,第一步计算完再处理进位.(见代码注释) 和乘法是类似的. #include <iostream> #include < ...
- hdu1002 A + B Problem II(高精度加法) 2016-05-19 12:00 106人阅读 评论(0) 收藏
A + B Problem II Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) ...
- POJ 3181 Dollar Dayz(全然背包+简单高精度加法)
POJ 3181 Dollar Dayz(全然背包+简单高精度加法) id=3181">http://poj.org/problem?id=3181 题意: 给你K种硬币,每种硬币各自 ...
- leetcode 67. Add Binary (高精度加法)
Given two binary strings, return their sum (also a binary string). For example,a = "11"b = ...
- leetcode 66. Plus One(高精度加法)
Given a non-negative number represented as an array of digits, plus one to the number. The digits ar ...
- SCAU1143 多少个Fibonacci数--大菲波数【杭电-HDOJ-1715】--高精度加法--Fibonacci数---大数比较
/*******对读者说(哈哈如果有人看的话23333)哈哈大杰是华农的19级软件工程新手,才疏学浅但是秉着校科联的那句“主动才会有故事”还是大胆的做了一下建一个卑微博客的尝试,想法自己之后学到东西都 ...
随机推荐
- 逆置单链表(基于c语言)
直接插入全部代码:(reverseLinklist函数是逆置操作) #include <stdio.h> #include <stdlib.h> #include <as ...
- web服务器-nginx配置文件
web服务器-nginx配置文件 一 nginx配置文件 #启动子进程程序的默认用户 #user nobody #一个主进程和多个工作进程.工作进程是单进程的,且不需要特殊授权即可运行:这里定义的是工 ...
- Mysql之B+树索引实战
索引代价 空间上的代价 一个索引都对应一棵B+树,树中每一个节点都是一个数据页,一个页默认会占用16KB的存储空间,所以一个索引也是会占用磁盘空间的. 时间上的代价 索引是对数据的排序,那么当对表中的 ...
- zookeeper有几种部署模式? zookeeper 怎么保证主从节点的状态同步?
一.zookeeper的三种部署模式 Zookeeper 有三种部署模式分别是单机模式.伪集群模式.集群模式.这三种模式在不同的场景下使用: 单机部署:一般用来检验 Zookeeper 基础功能,熟悉 ...
- SpringMVC怎么样设定重定向和转发的?
(1)转发:在返回值前面加"forward:",譬如"forward:user.do?name=method4" (2)重定向:在返回值前面加"red ...
- requests库获取响应流进行转发
遇到了一个问题,使用requests进行转发 requests响应流的时候,出现各种问题,问题的描述没有记录,不过Debug以下终于解决了问题.......下面简单的描述解决方案 response = ...
- memcached 和 MySQL 的 query ?
cache 相比,有什么优缺点? 把 memcached 引入应用中,还是需要不少工作量的.MySQL 有个使用方便的 query cache,可以自动地缓存 SQL 查询的结果,被缓存的 SQL 查 ...
- vue钩子函数的妙用之“created()和activated()”
一.created() 在创建vue对象时,当html渲染之前就触发: 但是注意,全局vue.js不强制刷新或者重启时只创建一次, 也就是说,created()只会触发一次: 二.activated( ...
- ctfhub密码口令
弱口令 进入环境 使用burpsuit抓包爆破 密码长度不一样应该密码就为他 即可找到 默认口令 进入环境一开始不懂百度借鉴原来是要看常见设备默认口令 很快就找到了 一个一个的试 即可获得答案
- 4.2 ROS节点运行管理launch文件
4.2 ROS节点运行管理launch文件 关于 launch 文件的使用我们已经不陌生了,在第一章内容中,就曾经介绍到: 一个程序中可能需要启动多个节点,比如:ROS 内置的小乌龟案例,如果要控制乌 ...