#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
typedef pair<int, int> ii;
const int INF = 1e9;
const ll LINF = 1e18;
struct BigInt {
static const int BASE = 1e9;
static const int B = 9;
vector<int> a;
BigInt() {}
BigInt(ll x) {
for (; x > 0; x /= BASE) {
a.push_back(x % BASE);
}
}
BigInt(const string &s) {
for (int i = (int)s.size() - 1; i >= 0; i -= B) {
int beg = max(0, i - B + 1);
int len = i - beg + 1;
int block = stoi(s.substr(beg, len));
a.push_back(block);
}
trim();
}
void trim() {
while (!a.empty() && a.back() == 0) {
a.pop_back();
}
}
bool isZero() {
return (a.empty());
}
BigInt operator*=(const BigInt &other) {
int n = a.size(), m = other.a.size();
vector<int> c(n + m, 0);
for (int i = 0; i < n; i++) {
int carry = 0;
for (int j = 0; j < m || carry; j++) {
ll cur = c[i + j] + 1ll * a[i] * (j < m ? other.a[j] : 0) + carry;
c[i + j] = cur % BASE;
carry = cur / BASE;
}
}
swap(a, c);
trim();
return *this;
}
BigInt operator*(const BigInt &other) const {
return BigInt(*this) *= other;
}
friend istream& operator>>(istream &in, BigInt &num) {
string s;
in >> s;
num = BigInt(s);
return in;
}
friend ostream& operator<<(ostream &out, const BigInt &num) {
out << (num.a.empty() ? 0 : num.a.back());
for (int i = (int)num.a.size() - 2; i >= 0; i--) {
out << setw(B) << setfill('0') << num.a[i];
}
return out;
}
};
int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
int t; cin >> t;
while (t--) {
BigInt a, b;
cin >> a >> b;
cout << a * b << '\n';
}
}
I2luY2x1ZGUgPGJpdHMvc3RkYysrLmg+IAoKdXNpbmcgbmFtZXNwYWNlIHN0ZDsgIAoKdHlwZWRlZiBsb25nIGxvbmcgbGw7ICAKdHlwZWRlZiBwYWlyPGludCwgaW50PiBpaTsgIAoKY29uc3QgaW50IElORiA9IDFlOTsgIApjb25zdCBsbCBMSU5GID0gMWUxODsgIAoKc3RydWN0IEJpZ0ludCB7CQoJc3RhdGljIGNvbnN0IGludCBCQVNFID0gMWU5OyAKCXN0YXRpYyBjb25zdCBpbnQgQiA9IDk7IAoKCXZlY3RvcjxpbnQ+IGE7IAoKCUJpZ0ludCgpIHt9CgoJQmlnSW50KGxsIHgpIHsKCQlmb3IgKDsgeCA+IDA7IHggLz0gQkFTRSkgewoJCQlhLnB1c2hfYmFjayh4ICUgQkFTRSk7IAoJCX0KCX0KCglCaWdJbnQoY29uc3Qgc3RyaW5nICZzKSB7CgkJZm9yIChpbnQgaSA9IChpbnQpcy5zaXplKCkgLSAxOyBpID49IDA7IGkgLT0gQikgewoJCQlpbnQgYmVnID0gbWF4KDAsIGkgLSBCICsgMSk7IAoJCQlpbnQgbGVuID0gaSAtIGJlZyArIDE7ICAKCQkJaW50IGJsb2NrID0gc3RvaShzLnN1YnN0cihiZWcsIGxlbikpOyAKCQkJYS5wdXNoX2JhY2soYmxvY2spOyAKCQl9CQoJCXRyaW0oKTsKCX0KCgl2b2lkIHRyaW0oKSB7CgkJd2hpbGUgKCFhLmVtcHR5KCkgJiYgYS5iYWNrKCkgPT0gMCkgewoJCQlhLnBvcF9iYWNrKCk7IAoJCX0KCX0KCglib29sIGlzWmVybygpIHsKCQlyZXR1cm4gKGEuZW1wdHkoKSk7IAoJfQoJCglCaWdJbnQgb3BlcmF0b3IqPShjb25zdCBCaWdJbnQgJm90aGVyKSB7CgkJaW50IG4gPSBhLnNpemUoKSwgbSA9IG90aGVyLmEuc2l6ZSgpOwoJCXZlY3RvcjxpbnQ+IGMobiArIG0sIDApOyAgCgkJZm9yIChpbnQgaSA9IDA7IGkgPCBuOyBpKyspIHsKCQkJaW50IGNhcnJ5ID0gMDsgIAoJCQlmb3IgKGludCBqID0gMDsgaiA8IG0gfHwgY2Fycnk7IGorKykgewoJCQkJbGwgY3VyID0gY1tpICsgal0gKyAxbGwgKiBhW2ldICogKGogPCBtID8gb3RoZXIuYVtqXSA6IDApICsgY2Fycnk7ICAgCgkJCQljW2kgKyBqXSA9IGN1ciAlIEJBU0U7IAoJCQkJY2FycnkgPSBjdXIgLyBCQVNFOyAKCQkJfQoJCX0KCQlzd2FwKGEsIGMpOyAKCQl0cmltKCk7CgkJcmV0dXJuICp0aGlzOyAKCX0KCglCaWdJbnQgb3BlcmF0b3IqKGNvbnN0IEJpZ0ludCAmb3RoZXIpIGNvbnN0IHsKCQlyZXR1cm4gQmlnSW50KCp0aGlzKSAqPSBvdGhlcjsgCgl9CgoJZnJpZW5kIGlzdHJlYW0mIG9wZXJhdG9yPj4oaXN0cmVhbSAmaW4sIEJpZ0ludCAmbnVtKSB7CgkJc3RyaW5nIHM7CgkJaW4gPj4gczsgCQoJCW51bSA9IEJpZ0ludChzKTsgIAoJCXJldHVybiBpbjsgCgl9CgoJZnJpZW5kIG9zdHJlYW0mIG9wZXJhdG9yPDwob3N0cmVhbSAmb3V0LCBjb25zdCBCaWdJbnQgJm51bSkgewoJCW91dCA8PCAobnVtLmEuZW1wdHkoKSA/IDAgOiBudW0uYS5iYWNrKCkpOyAKCQlmb3IgKGludCBpID0gKGludCludW0uYS5zaXplKCkgLSAyOyBpID49IDA7IGktLSkgewoJCQlvdXQgPDwgc2V0dyhCKSA8PCBzZXRmaWxsKCcwJykgPDwgbnVtLmFbaV07IAoJCX0KCQlyZXR1cm4gb3V0OyAKCX0KfTsgCgppbnQgbWFpbigpIHsKCWlvczo6c3luY193aXRoX3N0ZGlvKGZhbHNlKTsgCgljaW4udGllKG51bGxwdHIpOyAJCglpbnQgdDsgY2luID4+IHQ7IAoKCXdoaWxlICh0LS0pIHsKCQlCaWdJbnQgYSwgYjsgCgkJY2luID4+IGEgPj4gYjsgICAKCQljb3V0IDw8IGEgKiBiIDw8ICdcbic7IAoJfQp9