大数除算演算

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;
}