大数乘法,超级简单模板

在算法竞赛中,高精度(大整数)乘法最容易出错的地方是进位处理前导零去除

这里为你提供一个最适合在比赛中快速默写、不易出错的 C++ 模板。它的核心技巧是模拟竖式乘法并利用下标规律num1 的第 i 位和 num2 的第 j 位相乘,其乘积一定会累加到结果数组的第 i + j + 1 位,而进位会落在 i + j 位。

cpp 复制代码
#include <iostream>
#include <vector>
#include <string>

using namespace std;

string multiply(string num1, string num2) {
    // 1. 特判 0 的情况,防止最后输出空字符串或多个 0
    if (num1 == "0" || num2 == "0") return "0";
    
    int n = num1.size(), m = num2.size();
    // 2. 两个数相乘,最大长度不会超过它们的长度之和
    vector<int> res(n + m, 0);

    // 3. 从右向左遍历(从低位到高位)
    for (int i = n - 1; i >= 0; i--) {
        for (int j = m - 1; j >= 0; j--) {
            // 当前乘积 + 原有进位
            int sum = (num1[i] - '0') * (num2[j] - '0') + res[i + j + 1];
            
            // 更新当前位
            res[i + j + 1] = sum % 10;
            // 更新进位(注意这里是 +=,因为进位可能累积)
            res[i + j] += sum / 10;
        }
    }

    // 4. 转回字符串并去除前导零
    string ans = "";
    for (int p : res) {
        // 只要 ans 不是空的,或者当前数字不是 0,就加进去
        if (!(ans.empty() && p == 0)) {
            ans.push_back(p + '0');
        }
    }
    
    return ans;
}
相关推荐
cpp_25015 小时前
P1024 [NOIP 2001 提高组] 一元三次方程求解
数据结构·c++·算法·题解·二分答案·洛谷·csp
Gofarlic_oms110 小时前
利用API实现ANSYS许可证管理自动化集成
运维·服务器·开发语言·matlab·自动化·负载均衡
AI+程序员在路上11 小时前
VS Code 完全使用指南:下载、安装、核心功能与 内置AI 编程助手实战
开发语言·人工智能·windows·开源
田梓燊11 小时前
力扣:23.合并 K 个升序链表
算法·leetcode·链表
invicinble11 小时前
这里对java的知识体系做一个全域的介绍
java·开发语言·python
catchadmin11 小时前
使用 PHP TrueAsync 改造 Laravel 协程异步化的可行路径
开发语言·php·laravel
wbs_scy12 小时前
【Linux 线程进阶】进程 vs 线程资源划分 + 线程控制全详解
java·开发语言
re林檎12 小时前
算法札记——4.27
算法
AI人工智能+电脑小能手12 小时前
【大白话说Java面试题】【Java基础篇】第15题:JDK1.7中HashMap扩容为什么会发生死循环?如何解决
java·开发语言·数据结构·后端·面试·哈希算法
数据牧羊人的成长笔记12 小时前
逻辑回归与Softmax回归
算法·回归·逻辑回归