A除以B (20)
本题要求计算A/B,其中A是不超过1000位的正整数,B是1位正整数。你需要输出商数Q和余数R,
使得A = B * Q + R成立。
输入格式:
输入在1行中依次给出A和B,中间以1空格分隔。
输出格式:
在1行中依次输出Q和R,中间以1空格分隔。
输入样例:
123456789050987654321 7
输出样例:
17636684150141093474 3
#include<iostream>
#include<string>
using namespace std;
int main(){
string a;
int b;
cin>>a>>b;
int len=a.length();
int t=0;
int temp=0;
t=(a[0]-'0')/b;
if((t!=0&&len>1)||len==1){
cout<<t;
}
temp=(a[0]-'0')%b;
for(int i=1;i<len;i++){
t=(temp*10+a[i]-'0')/b;
cout<<t;
temp=(temp*10+a[i]-'0')%b;
}
cout<<" "<<temp;
}
//问题:之前自己写的使用了Num[] 数组表示单个数字,但调用a[i+1],a[i+2]
//使得问题过于混乱,事实只需要两个中间变量进行替换 ,更简化
//同时需要考虑第一个数字是否存在的问题!!