#include<iostream>
#include<vector>
#include<algorithm>
using namespace std;
//A/b,商为C,余数为r
vector<int> div(vector<int>&A,int b,int&r)//r是引用
{
vector<int> C;
r=0;
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();//除去前导零
return C;
}
int main()
{
string a;
int b;
int r;
cin>>a>>b;
vector<int> A;
for(int i=a.size()-1;i>=0;i--)A.push_back(a[i]-'0');
vector<int> C=div(A,b,r);
for(int i=C.size()-1;i>=0;i--)printf("%d",C[i]);
cout<<endl<<r<<endl;
return 0;
}
第一章 基础算法 (二):高精度除法
最新推荐文章于 2024-08-31 15:34:19 发布