1017. A除以B (20)

2017-06-25  本文已影响0人  小路_

本题要求计算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 temp=0,guard=0;     
    for(int i=0;i<A.length();++i){
        temp=temp*10+A[i]-48;  
        if(temp>=B){
            cout<<temp/B;
            guard=1;
        }
        else if(guard) cout<<0;
        temp=temp%B;
    }
    if(guard==0) cout<<0;
    cout<<" "<<temp<<endl;
    
    return 0;
 } 
上一篇 下一篇

猜你喜欢

热点阅读