高精度:大数相乘

题目链接:https://www.acwing.com/problem/content/795/
数据范围
1≤A的长度≤100000,
1≤B≤10000
输入样例:
2
3
输出样例:
6
思路:其实大数的加减乘除都是一个道理啦。
代码实现:

#include<bits/stdc++.h>
using namespace std;
#define rep(i,a,n) for(int i=a;i<=n;i++)
typedef long long ll;
const int INF=0x3f3f3f3f;
const int MAXN=2e5+5;
vector<int> mul( vector<int> &A, int b)
{
    vector<int> C;
    int t = 0;
    for(int i = 0; i < A.size() || t; i ++ ){
        t += A[i] * b;
        C.push_back(t % 10);
        t /= 10;
    }
    return C;
}
int main()
{
    ios::sync_with_stdio(0);
    cin.tie(0);cout.tie(0);
    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');
    vector<int> C=mul(A, b);
    for(int i = C.size() - 1; i >= 0; i -- ) printf("%d",C[i]);
    return 0;
}

发布了61 篇原创文章 · 获赞 0 · 访问量 990

猜你喜欢

转载自blog.csdn.net/Satur9/article/details/103996082