Description
求2个浮点数相加的和。
题目中输入输出中出现浮点数都有如下的形式:
P1P2...Pi.Q1Q2...Qj
对于整数部分,P1P2...Pi是一个非负整数。
对于小数部分,Qj不等于0。
Input
第1行是测试数据的组数n,每组测试数据占2行,分别是两个加数。每组测试数据之间有一个空行,每行数据不超过100个字符。
Output
n行,每组测试数据有一行输出是相应的和。由输入保证输出一定是一个小数部分不为0的浮点数,即由输入保证输出结果至少有一位小数。
Sample Input
2
0.111111111111111111111111111111
0.111111111111111111111111111111
10000000.655555555555555555555555555555
1.444444444444444444444444444445
Sample Output
0.222222222222222222222222222222
10000002.1
#include<stdio.h>
#include<string.h>
int main(){
int n;
int i,j,k,t=0;
int alen,blen;
char a[150],b[150];
int a1[150]={0},b1[150]={0},a2[150]={0},b2[150]={0},ans1[150]={0},ans2[150]={0};
scanf("%d",&n);
while(n--){
scanf("%s",&a);
scanf("%s",&b);
alen=strlen(a);
blen=strlen(b);
for(i=0;i<150;i++){
a1[i]=0;
a2[i]=0;
b1[i]=0;
b2[i]=0;
ans1[i]=0;
ans2[i]=0;
}
for(i=0;i<alen;i++){
if(a[i]=='.'){
k=0;
for(j=i-1;j>=0;j--){
a1[k++]=a[j]-'0';
}
k=0;
for(j=i+1;j<alen;j++){
a2[++k]=a[j]-'0';
}
}
}
for(i=0;i<blen;i++){
if(b[i]=='.'){
k=0;
for(j=i-1;j>=0;j--){
b1[k++]=b[j]-'0';
}
k=0;
for(j=i+1;j<blen;j++){
b2[++k]=b[j]-'0';
}
}
}
for(i=140;i>0;i--){
ans1[i]+=a2[i]+b2[i];
if(ans1[i]>=10){
ans1[i-1]+=1;
ans1[i]-=10;;
}
}
if (ans1[0]!=0) a1[0]=a1[0]+1;
for(i=0;i<=140;i++){
ans2[i]+=a1[i]+b1[i];
if(ans2[i]>=10){
ans2[i]%=10;
ans2[i+1]+=1;
}
}
for(i=140;i>=0;i--){
if(ans2[i]!=0){
for(j=i;j>=0;j--){
printf("%d",ans2[j]);
}
break;
}
}
if(i==-1) printf("0");
printf(".");
for(i=140;i>0;i--){
if(ans1[i]!=0){
for(j=1;j<=i;j++){
printf("%d",ans1[j]);
}
break;
}
}
if(i==0) printf("0");
printf("\n");
}
}