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

题解:AcWing 793 高精度乘法

【题目来源】

AcWing:793. 高精度乘法 - AcWing题库

【题目描述】

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

【输入】

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

【输出】

共一行,包含 \(A\times B\) 的值。

【输入样例】

2
3

【输出样例】

6

【解题思路】

image

【算法标签】

《AcWing 793 高精度乘法》 #高精度#

【代码详解】

#include <bits/stdc++.h>
using namespace std;// 大整数乘以小整数的函数
vector<int> mul(vector<int> &A, int b) {vector<int> C;  // 存储结果int t = 0;      // 进位值,初始为0// 遍历大整数的每一位for (int i = 0; i < A.size() || t; i++) {// 如果当前位存在,则计算乘积并加上进位if (i < A.size()) t += A[i] * b;// 存储当前位的计算结果C.push_back(t % 10);// 计算新的进位t /= 10;}// 去除前导零(保留至少一位)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');// 计算乘积auto C = mul(A, b);// 输出结果(需要逆序输出)for (int i = C.size() - 1; i >= 0; i--) printf("%d", C[i]);return 0;
}

【运行结果】

2
3
6
http://www.jsqmd.com/news/397324/

相关文章:

  • 希尔伯特空间
  • 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
  • 2026排阻行业佼佼者,这些厂商表现亮眼,低温漂高精密电阻/抗浪涌电阻/荣誉代理/排阻,排阻公司哪家强 - 品牌推荐师
  • Python use schedule as recycle timer