本题要求计算A/B,其中A是不超过1000位的正整数,B是1位正整数。你需要输出商数Q和余数R,使得A = B * Q + R成立。
输入在1行中依次给出A和B,中间以1空格分隔。
在1行中依次输出Q和R,中间以1空格分隔。
123456789050987654321 7
17636684150141093474 3
采用按位进行除法,余数进位的方式进行计算。
例如:
367 / 2
先计算 3 / 2 = 1 余 1
再计算 被除数加上余数进位过来的数进行计算
也就是 (6+1*10) / 2 = 8 余 0
再计算 (7+0*10) / 2 = 3 余 1
最后除出来的结果就是依次算式的得数 1 8 3
余数就是最后的余数 1
最后输出结果为:183 1
解题代码如下:
#include<iostream>
using namespace std;
const int N = 1e3 + 10;
int main()
{
char a[N];
int c[N];
int b, d = 0, i = 0;
scanf("%s%d", a, &b);
do {
c[i] = ((a[i] - 48)+d*10) / b;
d = ((a[i] - 48)+d*10) % b;
i++;
} while (a[i] >= '0'&&a[i] <= '9');
if (c[0] != 0)
for (int j = 0; j < i; j++)
{
printf("%d", c[j]);
}
else
for (int j = 1; j < i; j++)
{
printf("%d", c[j]);
}
printf(" %d", d);
return 0;
}
原文:https://www.cnblogs.com/fsh001/p/12205360.html