高精度乘法

高精度乘法

本篇计算的是 高精度整数乘以一个较小的整数。(都是非负的,负数只需要稍作加工即可)

高精度数指的是一个非常非常大的数字,一般的整型数据类型存不下它的值。

思路

高精度乘法当中的 代码计算方式与我们现实生活中自己做乘法时 不太一样。

对于这个题目,首先会先计算 6 * 15,然后进 9。

接着计算 5 * 15,答案是75,加上刚才的进位9,就是84。

以此类推。

而平时我们计算乘法,都是先计算 5 * 456956 然后加上 10 * 456956。

接着来看代码的实现。

题目

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

输入格式

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

输出格式

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

数据范围

1 ≤ A 的长度 ≤ 100000 1 \le A 的长度 \le 100000 1≤A的长度≤100000,
0 ≤ B ≤ 10000 0 \le B \le 10000 0≤B≤10000

输入样例:

2
3

输出样例:

6

首先是准备阶段:

接着跟 高精度加法和减法当时的操作一样,倒着存储在vector容器中。

这里需要注意的是,题目当中的 b是可能为 0的,所以需要特判一下。

接着把高精度乘法封装成一个函数,然后用变量C接收,最后倒着遍历打印一遍 C。

mul函数的外壳长这个样子。

首先定义一个返回的vector容器C。

高精度加法和高精度乘法比较像,都需要定义一个进位。

这个 t 的含义就是 就是上一位的 进位。

接着遍历整个数字。

根据之前的思路,接下来 让 t 加上 此时A的这一位乘以 b.

此时 t 的个位就是这一位的结果。

接着再更新新的进位,只需要让 t /= 10即可。

跟高精度加法一样,最高位有可能会再次进位,而我们只遍历到了最高位,所以最后还需要插入进位,当然前提是不等于0.

最后返回我们的 vector容器C 即可。

完整代码:

cpp 复制代码
#include <iostream>
using namespace std;
#include <vector>

string a;
int b;
vector<int> A;

vector<int> mul(vector<int>& A, int& b)
{
    vector<int> C;
    int t = 0;
    for (int i = 0; i < A.size(); i++)
    {
        t += A[i] * b;
        C.push_back(t % 10);
        t /= 10;
    }
    if (t) C.push_back(t);
    return C;
}

int main()
{
    cin >> a >> b;
    if (b == 0)
    {
        cout << "0";
        return 0;
    }
    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--) cout << C[i];
    
    return 0;
}

相关推荐
Lenyiin4 分钟前
01.02、判定是否互为字符重排
算法·leetcode
鸽鸽程序猿19 分钟前
【算法】【优选算法】宽搜(BFS)中队列的使用
算法·宽度优先·队列
Jackey_Song_Odd20 分钟前
C语言 单向链表反转问题
c语言·数据结构·算法·链表
Watermelo61723 分钟前
详解js柯里化原理及用法,探究柯里化在Redux Selector 的场景模拟、构建复杂的数据流管道、优化深度嵌套函数中的精妙应用
开发语言·前端·javascript·算法·数据挖掘·数据分析·ecmascript
乐之者v29 分钟前
leetCode43.字符串相乘
java·数据结构·算法
A懿轩A1 小时前
C/C++ 数据结构与算法【数组】 数组详细解析【日常学习,考研必备】带图+详细代码
c语言·数据结构·c++·学习·考研·算法·数组
古希腊掌管学习的神1 小时前
[搜广推]王树森推荐系统——矩阵补充&最近邻查找
python·算法·机器学习·矩阵
云边有个稻草人2 小时前
【优选算法】—复写零(双指针算法)
笔记·算法·双指针算法
半盏茶香2 小时前
在21世纪的我用C语言探寻世界本质 ——编译和链接(编译环境和运行环境)
c语言·开发语言·c++·算法
忘梓.2 小时前
解锁动态规划的奥秘:从零到精通的创新思维解析(3)
算法·动态规划