#include // #include // using namespace std; // using namespace atcoder; // #define int long long #define rep(i, n) for(int i = 0;i<(int)(n);i++) #define all(v) (v).begin(),(v).end() using ll = long long; using lint = long long; using P = std::pair; int main(void) { int n,m,p; std::cin >> n >> m >> p; std::vector v(n); rep(i, n) { std::cin >> v[i]; if(v[i]<=m&&v[i]%p==0) { while(v[i]%p==0) v[i]/=p; } } std::sort(v.rbegin(),v.rend()); int ans = 0; if(v.front()==1) ans=-1; else { int x = 1; while(x<=m) x*=v.front(),ans++; } std::cout << ans << std::endl; return 0; }