当前位置: 首页 > news >正文

[C++] 大数减/除法

目录

  • 高精度博客 - 前两讲
  • 高精度减法
  • 高精度除法
  • 高精度系列函数完整版

高精度博客 - 前两讲

讲次名称链接
高精加法[C++] 高精度加法(作用 + 模板 + 例题)
高精乘法[C++] 高精度乘法

高精度减法

void subBIG(int x[], int y[], int z[]){z[0] = max(x[0], y[0]);for(int i = 1; i <= z[0]; i++) z[i] = x[i] - y[i];for(int i = 1; i <= z[0]; i++){if(z[i] < 0){z[i] += 10;z[i + 1]--;}}while(z[z[0]] == 0 && z[0] > 1) z[0]--;
}

这个函数的思路还是在模拟列竖式, 最后的while是删除前缀0(以免出现类似000000的结果, 仅返回0)

高精度除法

记忆版

void divBIG(int x[],int y,int z[]){z[0] = x[0];int r = 0;for(int i = z[0]; i >= 1; i--){int t = r * 10 + x[i];z[i] = t / y;r = t % y;}while(z[z[0]] == 0 && z[0] > 1) z[0]--;
}

讲解版

void divBIG(int x[],int y,int z[]){z[0] = x[0];							// 有效位数设置// 模拟列竖式int r = 0;for(int i = z[0]; i >= 1; i--){			// 倒序循环int t = r * 10 + x[i];z[i] = t / y;r = t % y;}while(z[z[0]] == 0 && z[0] > 1) z[0]--;	// 去除前导零
}

高精度系列函数完整版

我们的3讲高精度即将结束, 给出完整的函数代码~

void s2BIG(string s, int a[]){int len = s.size();for(int i = 1; i <= len; i++){a[i] = s[len - i] - '0';}a[0] = len;
}void i2BIG(int n, int a[]){int cur = 0;while(n > 0){cur++;a[cur] = n % 10;n /= 10;}if(cur == 0) cur++;a[0] = cur;
}void printBIG(int a[]){int len = a[0];for(int i = len; i > 0; i--){cout << a[i];}cout << endl;
}void addBIG(int x[], int y[], int z[]){z[0] = max(x[0], y[0]);for(int i = 1; i <= z[0]; i++)z[i] = x[i] + y[i];for(int i = 1; i <= z[0]; i++){z[i + 1] += z[i] / 10;z[i] %= 10;if(z[z[0] + 1] != 0)z[0]++;}
}/*
如果x比y小, 则返回true
否则(y >= x)返回false
*/
bool cmpBIG(int x[], int y[]){int lx = x[0], ly = y[0];if(lx != ly) return lx < ly;for(int i = lx; i >= 1; i--){if(x[i] != y[i]) return x[i] < y[i];}return false;
}void mulBIG(int x[], int y[], int z[])
{for (int i = 1; i <= x[0]; i++){for (int j = 1; j <= y[0]; j++){z[i + j - 1] += x[i] * y[j];}}z[0] = max(x[0], y[0]);for (int i = 1; i <= z[0]; i++){z[i + 1] += z[i] / 10;z[i] %= 10;if (z[z[0] + 1] > 0) z[0]++;}while (z[z[0]] == 0 && z[0] > 1) z[0]--;
}void subBIG(int x[], int y[], int z[]){z[0] = max(x[0], y[0]);for(int i = 1; i <= z[0]; i++) z[i] = x[i] - y[i];for(int i = 1; i <= z[0]; i++){if(z[i] < 0){z[i] += 10;z[i + 1]--;}}while(z[z[0]] == 0 && z[0] > 1) z[0]--;
}void divBIG(int x[],int y,int z[]){z[0] = x[0];int r = 0;for(int i = z[0]; i >= 1; i--){int t = r * 10 + x[i];z[i] = t / y;r = t % y;}while(z[z[0]] == 0 && z[0] > 1) z[0]--;
}

相关文章:

  • 鸿蒙 所有API缩略图鉴
  • Web3 初学者的第一个实战项目:留言上链 DApp
  • 质量保证计划,软件质量计划书,软件质量方案(word原件)
  • FHE 之 面向小白的引导(Bootstrapping)
  • 6.秒杀优化
  • HTTP:十三.HTTP日志
  • 数据库版本控制工具--flyway
  • CSDN 中 LaTeX 数学公式输入方法
  • 思考:(linux) tmux 超级终端快速入门的宏观思维
  • c++ using使用
  • 通信原理绪论
  • JDBC工具类的三个版本
  • 【python】json解析:invalid literal for int() with base 10: ‘\“\“‘“
  • 工厂节能新路径:精准节能的深度剖析
  • YOLO目标检测算法评估标准
  • C++STL——stack,queue
  • Python3(30) 正则表达式
  • 两数相加(2)
  • Profinet转CanOpen网关,打破协议壁垒的关键技术
  • 国内特殊车辆检测数据集VOC+YOLO格式4930张3类别
  • 印度32座机场暂停民用航班运营,印称在边境多处发现无人机
  • 习近平会见古共中央第一书记、古巴国家主席迪亚斯-卡内尔
  • 4月金融数据前瞻:受去年低基数因素影响,社融增量有望同比大幅多增
  • 欧盟公布关税反制清单,瞄准美国飞机、汽车等产品
  • 以总理内塔尼亚胡称决心彻底击败哈马斯
  • 商务部再回应中美经贸高层会谈