Documente Academic
Documente Profesional
Documente Cultură
In continuare voi prezenta cum se pot realiza operatii pe numere mari cu foarte putine linii de
cod. In general, multi programatori se complica la aceste operatii, desi nu este nevoie! Vom
considera ca numerele mari sunt vectori in care elementul de indice 0 indica lungimea
numarului, iar cifrele sunt retinute in ordinea inversa decat cea a citirii.
int i, j, t, C[NR_CIFRE];
memset(C, 0, sizeof(C));
for (i = 1; i <= A[0]; i++)
{
for (t=0, j=1; j <= B[0] || t; j++, t/=10)
C[i+j-1]=(t+=C[i+j-1]+A[i]*B[j])%10;
if (i + j - 2 > C[0]) C[0] = i + j - 2;
}
memcpy(A, C, sizeof(C));
}