博客
关于我
高精度:大数相除
阅读量: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/

你可能感兴趣的文章
Mysql——深入浅出InnoDB底层原理
查看>>
MySQL“被动”性能优化汇总
查看>>
MySQL、HBase 和 Elasticsearch:特点与区别详解
查看>>
MySQL、Redis高频面试题汇总
查看>>
MYSQL、SQL Server、Oracle数据库排序空值null问题及其解决办法
查看>>
mysql一个字段为空时使用另一个字段排序
查看>>
MySQL一个表A中多个字段关联了表B的ID,如何关联查询?
查看>>
MYSQL一直显示正在启动
查看>>
MySQL一站到底!华为首发MySQL进阶宝典,基础+优化+源码+架构+实战五飞
查看>>
MySQL万字总结!超详细!
查看>>
Mysql下载以及安装(新手入门,超详细)
查看>>
MySQL不会性能调优?看看这份清华架构师编写的MySQL性能优化手册吧
查看>>
MySQL不同字符集及排序规则详解:业务场景下的最佳选
查看>>
Mysql不同官方版本对比
查看>>
MySQL与Informix数据库中的同义表创建:深入解析与比较
查看>>
mysql与mem_细说 MySQL 之 MEM_ROOT
查看>>
MySQL与Oracle的数据迁移注意事项,另附转换工具链接
查看>>
mysql丢失更新问题
查看>>
MySQL两千万数据优化&迁移
查看>>
MySql中 delimiter 详解
查看>>