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

题解:AcWing 794 高精度除法

【题目来源】

AcWing:794. 高精度除法 - AcWing题库

【题目描述】

给定两个非负整数(不含前导 \(0\)\(A\)\(B\) ,请你计算 \(A/B\) 的商和余数。

【输入】

共两行,第一行包含整数 \(A\),第二行包含整数 \(B\)

【输出】

共两行,第一行输出所求的商,第二行输出所求余数。

【输入样例】

7
2

【输出样例】

3
1

【解题思路】

image

【算法标签】

《AcWing 794 高精度除法》 #高精度#

【代码详解】

#include <bits/stdc++.h>
using namespace std;// 大整数除法函数:A / b,返回商C,余数通过引用r返回
vector<int> div(vector<int> &A, int b, int &r) {vector<int> C;  // 存储商r = 0;          // 初始化余数为0// 从高位到低位处理(因为除法是从高位开始的)for (int i = A.size() - 1; i >= 0; i--) {r = r * 10 + A[i];       // 当前被除数 = 余数*10 + 当前位C.push_back(r / b);      // 计算当前位的商r %= b;                 // 计算新的余数}// 反转商数组,因为我们是按高位到低位计算的reverse(C.begin(), C.end());// 去除前导零(保留至少一位)while (C.size() > 1 && C.back() == 0) C.pop_back();return C;
}int main() {string a;  // 存储大整数的字符串形式int b;     // 除数(小整数)cin >> a >> b;vector<int> A;  // 存储大整数(逆序存储)// 将字符串转换为逆序的数字数组for (int i = a.size() - 1; i >= 0; i--) A.push_back(a[i] - '0');int r;  // 余数auto C = div(A, b, r);  // 计算商和余数// 输出商(需要逆序输出)for (int i = C.size() - 1; i >= 0; i--) printf("%d", C[i]);// 输出余数cout << endl << r << endl;return 0;
}

【运行结果】

7
2
3
1
http://www.jsqmd.com/news/397326/

相关文章:

  • 题解:AcWing 792 高精度减法
  • 题解:AcWing 793 高精度乘法
  • 希尔伯特空间
  • Prime1
  • 几个靠关键词获取流量的 独立站 的优秀站点
  • 卫星通信系统工程设计与应用【1.8】
  • 2025智能数字资产流转平台架构创新:AI应用架构师眼中的3大技术突破方向
  • Mac 续命神器!用 balenaetcher 制作 macOS Tahoe 启动盘,小白也能一键重装系统
  • XSLT `<template>` 标签详解
  • Bootstrap 导航栏
  • 数据湖架构深度解析:Delta Lake vs Iceberg vs Hudi
  • 题解:AcWing 790 数的三次方根
  • 题解:AcWing 785 快速排序
  • 题解:AcWing 789 数的范围
  • 2026.2.20
  • R语言连接MySQL数据库的详细指南
  • 题解:AcWing 788 逆序对的数量
  • 题解:AcWing 787 归并排序
  • 第1.4节 最优化理论基础 习题练习
  • 题解:AcWing 786 第k个数
  • CSS 网页布局
  • Servlet 数据库访问
  • YOLO26改进26:全网首发--C3k2融合自研创新模块C3k2_GhostDynamicConv
  • YOLO26改进27:全网首发--C3k2融合自研改进模块RVB_EMA
  • jEasyUI 创建页脚摘要
  • MySQL 删除数据表
  • centos7 中 安装docker与使用
  • Ruby Socket 编程
  • Spring IOC容器:Bean生命周期与循环依赖解决
  • 2/20