本题要求计算 A/B,其中 A 是不超过 1000 位的正整数,B 是 1 位正整数。你需要输出商数 Q 和余数 R,使得 A=B×Q+R 成立。
输入格式:
输入在一行中依次给出 A 和 B,中间以 1 空格分隔。
输出格式:
在一行中依次输出 Q 和 R,中间以 1 空格分隔。
输入样例:
123456789050987654321 7
输出样例:
17636684150141093474 3
C++
#include <iostream>
#include <cmath>
#include <iomanip>
#include <cstring>
using namespace std;
int main()
{
string A;
int B,R;// R<B
cin >> A >> B;
int a=A[0]-'0';
int Num = A.size();
for (int i=0;i<Num;i++)
{
int q=a/B;
if((i!=0 || q!=0) && Num>1)
cout << q;
if(Num==1 && q==0) cout << q;//考虑A只有一位数且A<B的情况
int t=a%B;
a=t*10+A[i+1]-'0';
if(i==Num-1) R=t;
}
cout << ' ' << R;
return 0;
}
Python
a,b=input().split()
a=list(a)
b=int(b)
q=[]
r=''
for i in range(len(a)):
r+=a[i]
q.append(int(r)//b)
r=str(int(r)%b)
if q[0]==0 and len(a)>1:
del q[0]
print("".join(str(q[i]) for i in range(len(q))),r)