高精度算法_大数除以小数

给定两个非负整数A,B,请你计算 A / B的商和余数。

输入格式

共两行,第一行包含整数A,第二行包含整数B。

输出格式

共两行,第一行输出所求的商,第二行输出所求余数。

数据范围

1A1000001≤A的长度≤100000,
1B100001≤B≤10000
BB 一定不为0

输入样例:

7
2

输出样例:

3
1
#include <iostream>
#include <vector>
#include <algorithm>//
 
using namespace std;//
 
vector<int> div(vector<int>&A,int b,int &r)//使
{
  vector<int> C;//
  r=0;
  for(int i =A.size()-1;i>=0;i--)
  {
    r=r*10+A[i];//乘10
    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 ;//构_
 
  cin>>a>>b;//
 
  vector<int> A;
  for(int i=a.size()-1;i>=0;i--) A.push_back(a[i]-'0');//进vector
 
  int r;//
  auto C=div(A,b,r);//
 
  for(int i=C.size()-1;i>=0;i--) printf("%d",C[i]);//
  cout<<endl<<r<<endl;
 
  return 0;
}
 
 
 
posted @ 2020-08-30 13:08  WAsbry  阅读(548)  评论(0编辑  收藏  举报