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

洛谷 P1480 A/B Problem(高精度详解)c++

题目链接:P1480 A/B Problem - 洛谷

1.题目分析

1:说明这里是高精度除以低精度的形式,为什么不是高精度除以高精度的形式,是因为它很少见,它的模拟方式是用高精度减法来做的,并不能用小学列竖式的方法模拟出来,但是如果用高精度除低精度的话,是可以用小学的方式模拟出来的,并且是有可能遇到,所以我们这里只了解高精度除以低精度就可以,至于高精度除高精度,大家感兴趣可以在网上搜一下

2.算法原理

解法:模拟列竖式计算的过程

  1. 用字符串读入第一个数,拆分每一位,逆序放在数组中
  2. 利用数组,模拟列竖式除法的过程

模拟一下小学列竖式除法过程,比如1234除4最高位是1,1/45是除不尽的,因此商0,0×45=0,1-0=1,拿余数1和后面的2拼接起来,如何落实到代码,可以创建一个变量t来记录余数1,再让t×10+2就变成12了,接下来用12/45的时候依旧是商0余12,把它拼接成123的步骤和刚刚一样,让12×10+3变成123,接下来拿123/45,2×45=90,123-90=33,如何拿到商2和余数90呢?当前的t=123,除45就可以拿到2,模45就可以拿到33,所以计算过程就是一直在重复t乘10加当前数、除除数、模除数、的步骤,继续向后进行预算就可以了

有可能余数会超过int范围,因为b的范围是是1e9级别的数,让它乘10会变成1e10,会超过整型范围,所以使用long long来存储

代码:

#include <iostream>
using namespace std;const int N = 1e6 + 10;
typedef long long LL;int a[N], b, c[N]; //被除数、除数、结果
int la, lc;// 高精度除法的模板 - c = a / b (高精度 / 低精度)
void sub(int c[], int a[], int b)
{LL t = 0; // 标记每次除完之后的余数//除的时候是拿最高位试除的for (int i = la - 1; i >= 0; i--){// 计算当前的被除数t = t * 10 + a[i]; //拼接被除数 12*10+3=123c[i] = t / b;      //拿商    123/45=2t %= b;            //取余数  123%45=33}// 处理前导 0while (lc > 1 && c[lc - 1] == 0) lc--;
}int main()
{string x; cin >> x >> b;la = x.size();for (int i = 0; i < la; i++) a[la - 1 - i] = x[i] - '0';// 模拟除法的过程lc = la;sub(c, a, b); // c = a / bfor (int i = lc - 1; i >= 0; i--) cout << c[i];return 0;
}
http://www.lryc.cn/news/547870.html

相关文章:

  • JAVA入门——网络编程简介
  • Ubuntu 合上屏幕 不待机 设置
  • 捣鼓180天,我写了一个相册小程序
  • 短分享-Flink图构建
  • 【监督学习】支持向量机步骤及matlab实现
  • 机器学习-随机森林解析
  • Javaweb后端spring事务管理 事务四大特性ACID
  • 在Spring Boot + MyBatis中优雅处理多表数据清洗:基于XML的配置化方案
  • 【无标题】四色拓扑模型与宇宙历史重构的猜想框架
  • [特殊字符] Django 常用命令
  • mysql中如何保证没有幻读发生
  • Golang实践录:go发布版本信息收集
  • 字节跳动AI原生编程工具Trae和百度“三大开发神器”AgentBuilder、AppBuilder、ModelBuilder的区别是?
  • 【UCB CS 61B SP24】Lecture 21: Data Structures 5: Priority Queues and Heaps 学习笔记
  • mapbox高阶,结合threejs(threebox)添加三维球体
  • QEMU源码全解析 —— 块设备虚拟化(1)
  • IDEA中Git版本回退终极指南:Reset与Revert双方案详解
  • Flutter 学习之旅 之 flutter 使用 flutter_screenutil 简单进行屏幕适配
  • 实验一:在Windows 10/11下配置和管理TCP/IP
  • 基于hive的电信离线用户的行为分析系统
  • Rust WebAssembly 入门教程
  • 部署RabbitMQ集群详细教程
  • 20250306JIRA添加企业微信邮箱通知
  • 代码随想录算法训练营第五十七天 | 101. 孤岛的总面积 102. 沉没孤岛 103. 水流问题 104.建造最大岛屿
  • llamafactory大模型微调教程(周易大模型案例)
  • excel 斜向拆分单元格
  • 【JAVA架构师成长之路】【JVM实战】第2集:生产环境内存飙高排查实战
  • MATLAB实现遗传算法优化风电_光伏_光热_储热优化
  • JCRQ1河马算法+四模型对比!HO-CNN-GRU-Attention系列四模型多变量时序预测
  • react中的fiber和初次渲染