Files
python/GESP/Mkx/20250304_1_GaoJingDu.cpp
HuangHai 1f397eca87 'commit'
2025-08-30 18:35:01 +08:00

55 lines
1.1 KiB
C++

#include <bits/stdc++.h>
using namespace std;
const int N = 1e5 + 10;
const int WIDTH = 4; // 压4位
const int BASE = 10000; // 基数为10000
int a[N], al;
int b[N], bl;
// 字符串转压位数组(逆序存储)
void str2num(string s, int c[], int &cl) {
cl = 0;
for (int i = s.size() - 1; i >= 0; i -= WIDTH) {
int v = 0;
int st = max(i - WIDTH + 1, 0); // 最后一组可能不够4个长度
for (int j = st; j <= i; j++)
v = v * 10 + (s[j] - '0');
c[cl++] = v;
}
}
void mul(int a[], int &al, int b[], int &bl) {
vector<int> c(N, 0);
for (int i = 0; i < al; i++)
for (int j = 0; j < bl; j++)
c[i + j] += a[i] * b[j];
al = al + bl + 1;
for (int i = 0; i < al; i++) {
c[i + 1] += c[i] / BASE;
c[i] %= BASE;
}
for (int i = 0; i < al; i++)
a[i] = c[i];
while (al > 1 && a[al - 1] == 0)
al--;
}
int main() {
string x, y;
cin >> x >> y;
str2num(x, a, al), str2num(y, b, bl);
mul(a, al, b, bl);
for (int i = al - 1; i >= 0; i--)
printf("%d", a[i]);
return 0;
}