Cerința
Dorel trebuie să repare reţeaua de alimentare cu apă din oraşul lui. Pentru fiecare din cele n
străzi Dorel şi-a notat două numere naturale, raportul lor fiind lungimea conductei care trebuie înlocuită pe acea stradă. Pentru a destrăma mitul “Dorel, instalatorul dezastru”, el vă roagă să aflaţi lungimea totală a conductei de care are nevoie pentru a repara toate străzile, cu 20
de zecimale exacte.
Date de intrare
Fișierul de intrare error.in
conține pe prima linie numărul n
, iar pe următoarele n
linii câte două numere naturale nenule reprezentând numărătorul, respectiv numitorul raportului ce reprezintă lungimea conductei ce trebuie înlocuită pe strada respectivă.
Date de ieșire
Fișierul de ieșire error.out
va conține pe prima linie primele 20
de zecimale ale lungimii totale a conductei, despărţite prin spaţiu.
Restricții și precizări
1 ≤ n ≤ 100.000
- numerele notate de Dorel sunt naturale, nenule şi mai mici decât 1000
- pentru fiecare zecimală corectă, începând de la virgulă, se primeşte câte 1p ( dacă o zecimală e greşită, pentru următoarele după ea nu se mai acordă puncte )
#include <bits/stdc++.h> using namespace std; ifstream fin("error.in"); ofstream fout("error.out"); typedef int NrMare[33]; NrMare x,y; int n,a,b; void Adunare(NrMare x,NrMare y) { int i,t=0; if(x[0]<y[0]) x[0]=y[0]; for(i=1;i<=x[0];i++,t/=10) { t=x[i]+y[i]+t; x[i]=t%10; } if(t) x[++x[0]]=t; } int main() { fin>>n; x[0]=1; x[1]=0; for(int i=1;i<=n;++i) { fin>>a>>b; y[0]=30; for(int j=1;j<=30;++j) a%=b,a=a*10,y[30-j+1]=a/b; Adunare(x,y); } for(int i=30;i>10;--i) fout<<x[i]<<' '; return 0; }