hdu1002(简单大数加法)
A + B Problem II Problem Description Input Output Sample Input 2 Sample Output Case 1: Case 2: 简单大数:模拟手算。 为了便于计算,要将两个整数读成字符串,并且倒置(也有防止加法溢出额情况) ac代码 #include <stdio.h>
#include <cstring>
#define maxn 1000
char a[maxn];
char b[maxn];
char c[maxn+3];
void change(char a[]){
int len=strlen(a);
for(int i=0;i==0||i<len/2;i++){
int temp;
temp=a[i]-'0';
a[i]=a[len-i-1]-'0';
a[len-i-1]=temp;
}
if((len%2)==1)
a[len/2]=a[len/2]-'0';
}
void tsum(char a[],char b[],char c[]){
int yu=0;
int temp=0;
for(int i=0;i<maxn;i++){
temp=a[i]+b[i]+yu;
c[i]=temp%10;
yu=temp/10;
}
}
int main(){
int n;
while(scanf("%d",&n)!=EOF){
int ca=1;
int first=0;
while(n--){
memset(a,0,sizeof(a));
memset(b,sizeof(b));
if(first){
printf("n");
}else{
first=1;
}
printf("Case %d:n",ca++);
scanf("%s%s",a,b);
printf("%s + %s = ",b);
change(a);
change(b);
tsum(a,b,c);
int start=0;
for(start=maxn-1;c[start]==0;start--);
for(;start>=0;start--)
printf("%d",c[start]);
printf("n");
}
}
return 0;
}
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- 【Linux探索之旅】第三部分第一课:数据处理,慢条斯理
- 【Allwinner ClassA20类库分析】 2.free pascal语法及结构简
- DBGridEh Footer的设置和使用
- 3 Perl - 列表 - 列表赋值
- POJ 2429 GCD & LCM Inverse Pollard_rho大数因子分解
- 为Delphi开发MySQL.pas包装器
- Lua 与C/C++ 交互系列:利用模板技术在Lua Code中注册C++类
- 函数 – 在Inno Setup中实现脚本常量时的“标识符预期”或“
- [数据仓库--ETL]渐变维度(Slowly Changing Dimension)及其
- lua源码剖析2【转】