#define _CRT_SECURE_NO_WARNINGS #define _USE_MATH_DEFINES #define _SCL_SECURE_NO_WARNINGS #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #define MAX_MOD 1000000007 #define REP(i,n) for(int i = 0;i < n;++i) using namespace std; int sosuu_counter[110000][1000] = {}; vector whereis; map hogee; int main() { int n, k; scanf("%d%d", &n, &k); REP(i, n) { long long n; cin >> n; int cnt = 2; while (true) { if (n % cnt == 0) { sosuu_counter[cnt][i]++; n /= cnt; } else { cnt++; if (cnt > sqrt(n)) { hogee[n]++; whereis.push_back(n); goto ok; } } } ok:; } long long ans = 1; for (int i = 0;i < whereis.size();++i) { for (int q = 0;q < i;++q) { if (whereis[i] == whereis[q]) goto ah; } for (int q = 0;q < k && q < hogee[whereis[i]];++q) { ans = (ans*whereis[i]) % MAX_MOD; } ah:; } for (int i = 2;i <= 100000;++i) { sort(sosuu_counter[i], sosuu_counter[i] + 1000,greater()); int counter = 0; for (int q = 0;q < k;++q) { counter += sosuu_counter[i][q]; } for (int q = 0;q < counter;++q) { ans = (ans*i) % MAX_MOD; } } cout << ans % MAX_MOD << endl; }