题目描述
本题要求计算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>
int main(int argc, char** argv)
{
string a;
int b;
int q,r;
cin>>a>>b;
q=(a[0]-'0')/b;
if(a.length()==1||(q!=0&&a.length()>1)){
cout<<q;
}
r=(a[0]-'0')%b;
for(int i=0;i<a.length();i++){
q=(r*10+a[i]-'0')/b;
cout<<q;
r=(r*10+a[i]-'0')%b;
}
cout<<" "<<r;
return 0;
}
补充知识点:
string 字符串
- 遍历一个字符串的内容,可将这个字符串作为一维数组处理;
- 要使用字符串中的数字进行计算 例如a[0]对5取余,需:(a[0]-‘0’)%5;
- 但是仅输出某位时只需要类似形式:cout<<a[0];