高精度算法:加减乘除 (学习笔记)

加法:

现有vector<int>a,b;并且已经输入了内容且倒置

vector<int> plus(vector<int>a,vector<int> b){

int as = a.size();

int bs = b.size();

vector<int>total;

int carry = 0;

int ar = 0, br = 0; //读取位数

while (ar < as && br < bs) {

int tmp = aar++ + bbr+++carry;

if (tmp >= 10) {

carry = 1; //判断进位

tmp = tmp % 10;

}

else {

carry = 0; //没有进位需要记住去置空

}

total.emplace_back(tmp);

}

while (ar < as) {

int tmp = aar++ + carry;

if (tmp >= 10) {

carry = 1;

tmp %= 10;

}

else carry = 0;

total.emplace_back(tmp);

}

while (br < bs) {

int tmp = bbr++ + carry;

if (tmp >= 10) {

carry = 1;

tmp %= 10;

}

else carry = 0;

total.emplace_back(tmp);

}

if (carry == 1)total.emplace_back(carry);

return total; //记得回去倒置

}

可以判断长度后进行优雅的处理(假设a的长度大于等于b的)

For(int i=0,t=0;i<a.size();i++){

t+=ai;

If(i<b.size())t+=bi;

Total.emplace_back(t%10);

If(t>=10)t=1;

Else t=0;

}

这样的处理就更加的优雅了

减法

如果是两个整数的减法,需要确定一下两个数的大小,也就是我们需要再来一个cmp的函数来比较a和b的大小

Cmp:

int cmp(vector<int> a, vector<int> b) {

if (a.size() > b.size())return 1;//a更长一定更大

else if (a.size() < b.size()) {

return 0;//b更长,b更大

}

else{ //位数一样,从最高位开始比较,知道出现一个不一样的数,返回大的

for (int i = a.size() - 1; i >= 0;i--) {

if (ai != bi)return ai > bi;

}

}

return 1; //一样的就返回1

}

减法的具体的函数:(也是优雅的!!)

vector<int> sub(vector<int> a,vector<int> b){//a,b记得倒置

int as = a.size(); //默认a更大,我们可以在函数外进行比较后放入这个函数

vector<int>total;

int t = 0;

for (int i = 0; i < as; i++) {

t = ai - t;

if (i < b.size())t -= bi;

total.emplace_back((t + 10) % 10); //+10防止出现负数

if (t >= 0)t = 0;

else t = 1;

}

while (total.size() > 1 && total.back() == 0)total.pop_back();

return total;//记得倒置

}

一大乘以一小的乘法:

和加法一样,没有多大的区别,有的话就是carry的大小的最后carry的处理

直接上代码:

vector<int> time(vector<int> a,int b){

int as = a.size(); //记得倒置

int t = 0;

vector<int> total;

for (int i = 0; i < as; i++) {

t += ai * b;

total.emplace_back(t % 10);

t /= 10;

}

while (t) {

total.emplace_back(t % 10);

t /= 10;

}

return total;//记得倒置

}

一大除一小的除法:

只是需要涉及到的有3个翻转,具体的操作和大横线除法一样,从最高位开始计算,依次先

余数乘以10加上现在位的数除以b得到当前位置的答案,余数为当前余数求b的余数,最后一次翻转加上去掉后缀的0

具体的代码在下面:

vector<int> div(vector<int> a,int b){ //这里的a不用倒置,但是为了统一口径,就都倒置下

reverse(a.begin(),a.end()); //复原下

vector<int> res;

r = 0;

for (int i = a.size() - 1; i >= 0; i--) {

r = r * 10 + ai;

res.emplace_back(r / b);

r %= b;

}

reverse(res.begin(),res.end());

while (res.size() > 1 && res.back() == 0)res.pop_back();

return res; //记得倒置再输出结果

}

相关推荐
怪兽学LLM2 分钟前
LeetCode 438 找到字符串中所有字母异位词(Python 固定滑动窗口+字符计数解法)
python·算法·leetcode
满怀冰雪7 分钟前
第04篇-双指针算法-从有序数组到回文判断的高频解法
java·算法
CC数学建模8 分钟前
2026年江西省研究生数学建模竞赛1题:空间数据分析中的过拟合识别完整思路、代码、模型、文章,全网首发高质量分享!
python·算法·数学建模
leo__52015 分钟前
MATLAB实现牧羊人算法
开发语言·算法·matlab
Gauss松鼠会21 分钟前
【GaussDB】GaussDB SMP特性调优详解
java·服务器·前端·数据库·sql·算法·gaussdb
Tisfy26 分钟前
LeetCode 3689.最大子数组总值 I:What The Medium
算法·leetcode·题解·贪心·模拟·脑筋急转弯
葬送的代码人生27 分钟前
JavaScript 数组完全指南:从入门到实战
前端·javascript·算法
春日见42 分钟前
决策规划控制面经汇总
人工智能·深度学习·算法·机器学习·自动驾驶
Full Stack Developme42 分钟前
Java DFA算法
java·python·算法
fie88891 小时前
LBP + HOG 特征检测与识别 MATLAB 实现
数据结构·算法·matlab