大数除算演算
755 ワード
比較的簡単な文字列操作です.次の関数は、出力aをbで割って演算して商和残数を得ることである.
コード実装:
コード実装:
void division(char *a, int b)
{
int q, r, len;
len = strlen(a);
for (int i = 0; i < len; i++)a[i] -= '0';
if (len == 1)
{
r = a[0] % b;
printf("%d %d", a[0] / b, r);
}
else
{
for (int i = 0; i < len; i++)
{
if(i!=len-1)
if (a[i] / b != 0)
{
a[i + 1] += 10 * (a[i] % b);
a[i] /= b;
}
else
{
a[i + 1] += 10 * a[i];
a[i] = 0;
}
else if (i == len - 1)
{
r = a[i] % b;
a[i] /= b;
}
}
for (int i = 0; i < len; i++)
if (i == 0 && a[i] != 0)printf("%d", a[i]);
else if (i != 0)printf("%d", a[i]);
printf(" %d", r);
}
return 0;
}