#include using namespace std; typedef long long ll; template using Graph = vector>; #define REP(i, a, b) for (int i = (int)(a); i < (int)(b); i++) #define rep(i, a) REP(i, 0, a) #define EACH(i, a) for (auto i: a) #define ITR(x, a) for (__typeof(a.begin()) x = a.begin(); x != a.end(); x++) #define ALL(a) (a.begin()), (a.end()) #define HAS(a, x) (a.find(x) != a.end()) #define endl '\n' ll L, H; bool isprime(ll n) { if (n < 2) return false; if (n == 2) return true; if (n % 2 == 0) return false; for (ll i = 3; i * i <= n; i += 2) if (n % i == 0) return false; return true; } int main(void) { cin.tie(0); ios::sync_with_stdio(false); cin >> L >> H; ll ans = -1; ll s = (ll)sqrt(H); while (s > 0) { ll val = isprime(s); if (val == 1) { ll t = H/s; while (!isprime(t)) t--; cout << s << "*" << t << endl; ans = t*s; break; } s -= 1; } cout << ans << endl; return 0; }