高精度整数 - a+b(王道)
题目描述:
实现一个加法器,使其能够输出a+b的值。
输入:
输入包括两个数a和b,其中a和b的位数不超过1000位。
输出:
可能有多组测试数据,对于每组数据,输出a+b的值
样例输入:
2 6
1000000000000000000000 10000000000000000000000000000000000000000000
样例输出:
8
100000000000000000000000000000000000000000000
#include <iostream>
#include<string.h>
#include<cstdio>
using namespace std; struct bigInteger{
int digit[];//按四位数一个单位保存数值
int size;//下一个我们未使用的数组单元 void init(){//初始化
for(int i=;i<;i++)
digit[i] = ;
size = ;
} void set(char str[]){//从字符串中提取整数
init();
int L = strlen(str);//计算字符串长度
for(int i=L-,j=,t=,c=;i>=;i--){
/**从最后一个字符开始倒序遍历字符串,
j控制每4个字符转换成一个数字存入数组,
t临时保存字符转换位数字的中间值,
c表示当前位的权重,按1,10,100,1000顺序变化
*/
t += (str[i]-'')*c;//计算这个四位数中当前字符代表的数字,即数字乘以当前位权重
j++;//当前转换字符数增加
c *= ;//计算下一位权重
if(j == || i == ){//若已经连续转换四个字符,或者已经达到最后一个字符
digit[size++] = t;//这四个字符代表的四位数存入数组,size移动到下一个数组单元
j=;
t=;
c=;
}
}
} void output(){//将该高精度整数输出
for(int i=size-;i>=;i--){
if(i!=size-)
printf("%04d",digit[i]);//即当前输出的数字不是最高位数字,用%04的输出前导0,即当前数字不足4位时由0补充
else
printf("%d",digit[i]);//若是最高位,则无需输出前导0
}
printf("\n");
} bigInteger operator + (const bigInteger &A) const {//加法运算符
bigInteger ret;//返回两数相加的结果
ret.init();
int carry = ;//进位,初始值为0
for(int i=;i<A.size || i<size;i++){
int temp = A.digit[i]+digit[i]+carry;//计算两个整数当前位以及来自低位的进位和
carry = temp/;//计算该位的进位
temp %= ;//去除进位部分,取后四位
ret.digit[ret.size++] = temp;//保存该位结果
}
if(carry != ){//计算结束后若最高位有进位
ret.digit[ret.size++]=carry;//保存该进位
}
return ret;
}
}a,b,c; char str1[],str2[];
int main()
{
scanf("%s %s",str1,str2);
a.set(str1);//两个字符串分别设置两个高精度整数
b.set(str2);
c = a+b;
c.output();//输出
return ;
}
对于c和c++,要使用结构体保存一个高精度整数:
struct bigInteger{
int digit[];//按四位数一个单位保存数值
int size;//下一个我们未使用的数组单元
};
高精度整数 - a+b(王道)的更多相关文章
- Java中的高精度整数和高精度小数
在实际编码中,会遇到很多高精度的事例,比如,在计算金钱的时候就需要保留高精度小数,这样计算才不会有太大误差: 在下面的代码中,我们验证了,当两个float型的数字相加,得到的结果和我们的预期结果是有误 ...
- POJ 1504 Adding Reversed Numbers (水题,高精度整数加法)
题意:给两个整数,求这两个数的反向数的和的反向数,和的末尾若为0,反向后则舍去即可.即若1200,反向数为21.题目给出的数据的末尾不会出现0,但是他们的和的末尾可能会出现0. #include &l ...
- C++高精度整数加减乘除模板
其中高精度乘法通过了POJ2389,其他没有测过,不过应该是没有问题的. 其中高精度除法返回一对string,分别表示商和余数. 代码: #include <bits/stdc++.h> ...
- 无线OSS-高精度整数加法
#include<iostream> #include<string> using namespace std; int compareStr(string str1, str ...
- 九度OJ1198 a+b 【高精度整数】
题目地址:http://ac.jobdu.com/problem.php?pid=1198 题目描述: 实现一个加法器,使其能够输出a+b的值. 输入: 输入包括两个数a和b,其中a和b的位数不超过1 ...
- Java 高精度数字
BigInteger // 高精度整数 BigDecimal //高精度小数 小数位数不受限制
- 大整数相加 a+b 的c语言实现
终于来到我所期盼的高精度整数相加的题目了.这个题很经典,也算是一个很好的算法入门题吧. 如果是java的话,系统类库已经内置了BigInteger类,直接调用就可以很轻易地解决了.但是学习c的编写也是 ...
- FFT实现高精度乘法
你应该知道$FFT$是用来处理多项式乘法的吧. 那么高精度乘法和多项式乘法有什么关系呢? 观察这样一个$20$位高精度整数$11111111111111111111$ 我们可以把它处理成这样的形式:$ ...
- N的阶层(王道)
题目描述: 输入一个正整数N,输出N的阶乘. 输入: 正整数N(0<=N<=1000) 输出: 输入可能包括多组数据,对于每一组输入数据,输出N的阶乘 样例输入: 4 5 15 样例输出: ...
随机推荐
- module加载过程初步分析[更新中]【转】
转自:http://blog.chinaunix.net/uid-1817735-id-2837068.html 分析这个过程可以有助于我们认识在加载模块时出现的问题大抵在哪里了. 直接从sys_in ...
- python Nosql-redis 连接、管道
非关系型数据库和关系型数据库的差别: 非关系型数据库的优势: 性能NOSQL是基于键值对的,可以想象成表中的主键和值的对应关系,而且不需要经过SQL层的解析,所以性能非常高. 可扩展性同样也是因为基于 ...
- Ubunt 服务教程集锦
1.Ubuntu管理服务安装(强烈推荐最好用Xshell和Xftp): 序号 服务名 介绍 教程地址 windows客户端 1 VNC 可以图形界面管理Ubuntu ubuntu安装vncserver ...
- GUI界面------tkinter
import tkinter as tk class APP: def __init__(self,master): frame = tk.Frame(master) frame.pack(side ...
- Selenium2+python自动化59-数据驱动(ddt)【转载】
前言 在设计用例的时候,有些用例只是参数数据的输入不一样,比如登录这个功能,操作过程但是一样的.如果用例重复去写操作过程会增加代码量,对应这种多组数据的测试用例,可以用数据驱动设计模式,一组数据对应一 ...
- js的变量的有效域
function test(o) { var i=0; if(typeof o=="object") { var j=1; for(var k=0;k<10;k++) { c ...
- hdu 1316(大整数)
How Many Fibs? Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)To ...
- Java写到.txt文件,如何实现换行
http://blog.csdn.net/liangoo7/article/details/7882773 java中写.txt文件,实现换行的几种方法: 1.使用java中的转义符"\r\ ...
- python strip_tags 支持保留指定标签
#coding:utf-8 import re def strip_tags(string, allowed_tags=''): if allowed_tags != '': # Get a list ...
- HDU 4857 逃生 【拓扑排序+反向建图+优先队列】
逃生 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submission ...