博客
关于我
高精度:大数相除
阅读量:177 次
发布时间:2019-02-28

本文共 989 字,大约阅读时间需要 3 分钟。

数据范围

1≤A的长度≤100000,
1≤B≤10000
输入样例:
7
2
输出样例:
3
1

思路:其实都一样的,利用我们的人工模拟除法思维,虽然做除法时从高位开始存会比较方便,但为了模板和加减发一样更便于记忆,任然可以从低位开始存,只不过结果稍微处理一下就好。(我也不想说什么了,明明我的代码没有问题,但但它的测评器输出的商和余数的顺序就是反对,就是不让我过,,,orz)。

代码实现

#include
using namespace std;#define rep(i,a,n) for(int i=a;i<=n;i++)typedef long long ll;const int INF=0x3f3f3f3f;const int MAXN=2e5+5;//A / b,商是C,余数是rvector
div(vector
&A, int b, int &r){ vector
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();//去前导0 return C;}int main(){ string a; int b, r; vector
A; cin >> a >> b; for(int i = a.size() - 1; i >= 0; i -- ) A.push_back(a[i] - '0'); vector
C = div(A, b, r); for(int i = C.size() - 1; i >= 0; i -- ) printf("%d", C[i]); cout << endl << r << endl; return 0;}

转载地址:http://ubdj.baihongyu.com/

你可能感兴趣的文章
Neutron系列 : Neutron OVS OpenFlow 流表 和 L2 Population(7)
查看>>
new Blob()实现不同类型的文件下载功能
查看>>
New Concept English three (35)
查看>>
NEW DATE()之参数传递
查看>>
New Journey--工作五年所思所感小记
查看>>
new Queue(REGISTER_DELAY_QUEUE, true, false, false, params)
查看>>
New Relic——手机应用app开发达人的福利立即就到啦!
查看>>
new work
查看>>
new 一个button 然后dispose,最后这个button是null吗???
查看>>
NewspaceGPT的故事续写能力太强了
查看>>
NewspaceGPT绘制时序图
查看>>
NewspaceGPT绘制类图
查看>>
new一个对象的过程
查看>>
new和delete用法小结
查看>>
new对象时,JVM内部究竟藏了什么小秘密?
查看>>
new操作符的实现原理
查看>>
Next.js React Server Components 教程
查看>>
NextGen Mirth Connect XStream反序列化远程代码执行漏洞(CVE-2023-43208)
查看>>
next项目部署到服务器pm2进程守护
查看>>
nexus 介绍
查看>>