本题要求计算 A/B,其中 A 是不超过 1000 位的正整数,B 是 1 位正整数。你需要输出商数 Q 和余数 R,使得 A=B×Q+R 成立。
输入格式:
输入在一行中依次给出 A 和 B,中间以 1 空格分隔。
输出格式:
在一行中依次输出 Q 和 R,中间以 1 空格分隔。
输入样例:
123456789050987654321 7
输出样例:
17636684150141093474 3
五一回来后的第一道题
A是不超过1000位的正整数,肯定是需要用字符串来模拟的,int 和 long long int 肯定都是不够的,通过遍历A的每一位来输出结果
C++
#include<iostream>
#include<cstring>
using namespace std;
int main(){
string q;
int r;
cin>>q>>r;
int temp = q[0] - '0';
if(q.size() == 1)
cout<<temp / r<<" "<<temp % r<<endl;
else{
if(temp >= r)
{
cout<<temp / r;
temp %= r;
}
for(int i = 1;i<q.size();i++){
temp = temp * 10 + (q[i] - '0');
cout<<temp / r;
temp %= r;
}
cout<<" "<<temp<<endl;
}
return 0;
}