GUET-ACM-#1110-A+B增强版
来源:互联网 发布:mac是什么档次化妆品 编辑:程序博客网 时间:2024/06/10 13:54
Problem 1110 # A+B增强版
chair添加于2015-03-19 14:07:46
时间限制 : 1000MS 内存限制 : 65536KB
×提示 : 你已解决此题目。
问题描述
输入两个数A和B输出A + B的结果就可以了
输入
输入每组数据包含两个正整数A,B,范围在1~ 10e20之间。
输出
A+B的结果
输入范例
1 1234567890123456
1 2
输出范例
1234567890123457
3
分析:
这里的a+b是大数相加,int和long int都保存不了。
考虑用字符串的形式存放A和B。
为了方便计算,需要计算两字符串长度的差值,然后在短的字符串前补0,使两字符串的长度一致。
定义一个char类型的数组存放结果。
考虑到string,char,char*,int类型之间的转换,有点复杂,我这里直接用char数组。
在进行加法运算时,类似于汇编中add指令和adc指令的连用。低位直接相加,高位相加要加上来自低位的进位。
逐一取两字符串中对应的每一位相加,相加的结果mod10取余数并加上低位的进位保存在char类型的数组中。
对应的每一位相加的结果 /10取整数部分作为进位。
最后char数组中就是结果。
代码如下:
#include <iostream>#include<stdlib.h>#include<string>using namespace std;int main(){ string s1,s2; //定义两个字符串 int cha,i,CF; //cha表示俩字符串长度的差值,CF为进位标志 while(cin>>s1>>s2) { cha=abs(s1.length()-s2.length()); //取两个字符串长度的差值 for(i=0;i<cha;i++) //使两个字符串的长度一致,方便后续加法运算 if(s1.length()>s2.length()) s2="0"+s2; else s1="0"+s1; CF=0; //初始化进位CF int m,n,k; char ch[s1.length()]; //存放结果的char类型数组 for(i=s1.length()-1;i>=0;i--) //从字符串中逐一取数字出来进行加法运算 { m=s1[i]-'0'; //转换为int n=s2[i]-'0'; k=(m+n)%10+CF; //带进位的加法,取余数为结果 if(k==10) //特殊情况,当m+n=9且CF=1时,k=10 { k=0; //此时要让k=0,直接置进位CF为1 ch[i]=(k+'0'); CF=1; } else //普通情况 { ch[i]=(k+'0'); //k转为char类型 CF=(m+n)/10; //置进位CF } } ch[s1.length()]='\0'; //字符串结束 if(CF==1) cout<<"1"; //如果最高位有进位,则输出进位1 cout<<ch<<endl; /* string s3=ch; //也可以改为这样,把ch换回string字符串,这样 if(CF==1) //进位1就可以在字符串里面了 s3="1"+s3; cout<<s3<<endl; */ } return 0;}
0 0
- GUET-ACM-#1110-A+B增强版
- guet-acm-开挂的chair
- A+B问题acm
- [ACM]a+b problem
- [ACM]人见人爱A^B
- acm-A*B Problem
- acm-A-B Problem
- acm-A/B Problem
- ACM-A+B问题
- ACM A+B Problem
- codevs2609 A-B问题增强版超时81分代码
- ACM 1000--a加 b
- ACM 四月 A-B Problem
- acm-A+B Problem II
- acm-A+B Problem IV
- ACM-A+B Problem III
- ACM-C-1001-A+B
- ACM-C++-1001-A+B
- nmap端口探测原理初探
- nodejs获取参数
- hdu 2276(矩阵快速幂)
- gridx的使用
- 外观模式
- GUET-ACM-#1110-A+B增强版
- JAVA第一次作业 目标2
- python函数及函数式编程
- 项目从tomcat向weblogic迁移遇到的一些问题
- 使用 CCC(Carbon Copy Cloner)备份、还原OS X 10.10 Yosemite(优胜美地)系统
- 拷贝
- PAT--00-自测1. 打印沙漏(20)
- 回乡小农民 回乡小农民TXT全集下载 免费下载全本 小说下载 txt 电子书
- java第一次实习 目标1