关于L1-009 N个数求和 提问

#include<bits/stdc++.h>
using namespace std;
int main()
{
int n;
long long t;
long long z;
long long fz,fm;
scanf("%d",&n);
int a[101],b[101];
for(int i=0;i<n;i++)
{
scanf("%d/%d",&a[i],&b[i]);
}
fz=a[0],fm=b[0];
for(int i=1;i<n;i++)
{
fz=fz*b[i]+a[i]*fm;
fm=fm*b[i];
}
if(fz==0)printf("0");
else
{
t=__gcd(fz,fm);
fz=fz/t;
fm=fm/t;
}
if(fz%fm==0)
{
printf("%d",fz/fm);
return 0;
}
if(abs(fz)>abs(fm))
{
printf("%lld %lld/%lld",fz/fm,fz%fm,fm);
}
else
printf("%lld/%lld",fz%fm,fm);

}
提交结果为浮点错误,请问哪里错了?