AcWing 793. 高精度乘法——算法基础课题解

AcWing 793. 高精度乘法

题目描述

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

输入格式

共两行,第一行包含整数 A,第二行包含整数 B。

输出格式

共一行,包含 A×B 的值。

数据范围

1≤A 的长度≤100000,

0≤B≤100000

输入样例

cpp 复制代码
2
3

输出样例

cpp 复制代码
6

思路

将 B 看成一个整体再相乘,不要一位一位的乘!注意结果的前导 0!

C++

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

using namespace std;

void reverse(string &s) {
    size_t n = s.length();
    for (int i = 0; i < n / 2; ++i) {
        swap(s[i], s[n - i - 1]);
    }
}

string mul(string &a, int b) {
    reverse(a);
    int carry = 0;
    string result;
    for (size_t i = 0; i < a.size() || carry; ++i) {
        if (i < a.size()) carry += (a[i] - '0') * b;
        result.push_back(carry % 10 + '0');
        carry /= 10;
    }
    reverse(result);
    if (result[0] == '0') return "0";
    return result;
}

int main() {
    string a;
    int b;
    cin >> a >> b;
    cout << mul(a, b);
    return 0;
}
cpp 复制代码
#include <iostream>
#include <vector>

using namespace std;


vector<int> mul(vector<int> &A, int b)
{
    vector<int> C;

    int t = 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;
}

Go

go 复制代码
package main

import (
	"fmt"
	"strings"
)

func reverse(s string) string {
	r := []rune(s)
	l := len(r)
	for i := 0; i < l/2; i++ {
		r[i], r[l-i-1] = r[l-i-1], r[i]
	}
	return string(r)
}

func mul(a string, b int) string {
	a = reverse(a)
	carry := 0
	var result strings.Builder
	for i := 0; i < len(a) || carry > 0; i++ {
		if i < len(a) {
			carry += int(a[i]-'0') * b
		}
		result.WriteByte(uint8(carry%10) + '0')
		carry /= 10
	}
	resStr := reverse(result.String())
	if resStr[0] == '0' {
		return "0"
	}
	return resStr
}

func main() {
	var a string
	var b int
	fmt.Scanln(&a)
	fmt.Scanln(&b)
	fmt.Println(mul(a, b))
}

模板

cpp 复制代码
// C = A * b, A >= 0, b >= 0
vector<int> mul(vector<int> &A, int b)
{
    vector<int> C;

    int t = 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;
}
相关推荐
那雨倾城7 分钟前
用 YOLO Pose + Segmentation 在PiscCode构建“语义佛光”:一次实时视觉语义融合实验
图像处理·python·opencv·算法·yolo·计算机视觉·视觉检测
nnerddboy7 分钟前
解决传统特征波段选择的局限性:1.对偶学习
学习·算法·机器学习
CoovallyAIHub15 分钟前
自顶向下 or 自底向上?姿态估计技术是如何进化的?
深度学习·算法·计算机视觉
q_302381955625 分钟前
14.7MB轻量模型!NVIDIA Jetson边缘设备解锁工厂设备故障预警新方案
人工智能·python·算法·ascend·算子开发
爱敲点代码的小哥33 分钟前
C#哈希表遍历技巧全解析以及栈 堆 队列的认识
算法·哈希算法
xiaoxue..36 分钟前
爬楼梯问题:从递归到动态规划再到闭包的进化之路
javascript·算法·面试·动态规划
CoovallyAIHub38 分钟前
YOLO11算法深度解析:四大工业场景实战,开源数据集助力AI质检落地
深度学习·算法·计算机视觉
import_random43 分钟前
[推荐]embedding嵌入表示是如何生成的(实战)
算法
chao1898441 小时前
基于布谷鸟搜索算法的分布式电源多目标选址定容
算法
Xの哲學1 小时前
Linux IPsec 深度解析: 架构, 原理与实战指南
linux·服务器·网络·算法·边缘计算