高精度除法

#include<iostream>
#include<vector>
#include<algorithm>
using namespace std;
vector<int> div(vector<int> &A,int b,int &r){//被除数 除数 余数(以引用的方式计算并传值)
    r=0;//余数初始化为0
    vector<int> C;
    for(int i=A.size()-1;i>=0;i--)//除法从数的最高位开始除
    {
    r=r*10+A[i];//余数的表达式
    C.push_back(r/b);//商的这一位
    r%=b;//该位除完后,更新余数
    }
    reverse(C.begin(),C.end());//反转前后位以便主函数中输出
    while(C.size()>1&&C.back()==0) C.pop_back();//别忘了去除前导0
    return C;
}
int main(){
    string a;
    int b;
    vector<int> A;
    cin>>a>>b;
    for(int i=a.size()-1;i>=0;i--)
    A.push_back(a[i]-'0');//将字符数字转成整数
    int r;//余数
    auto C=div(A,b,r);
    for(int i=C.size()-1;i>=0;i--)
    cout<<C[i];
    cout<<endl<<r<<endl;
    return 0;
}

 

posted @ 2022-01-22 14:36  zzq12138  阅读(48)  评论(0)    收藏  举报