## https://yukicoder.me/problems/no/944 import heapq def main(): N, M, P = map(int, input().split()) A = list(map(int, input().split())) A.sort(reverse=True) p_array = [] for i in range(N): a = A[i] p_cnt = 0 while a % P == 0: a //= P p_cnt += 1 p_array.append((a, p_cnt)) answer = float("inf") for a, p_cnt in p_array: if a > 1: ans = 0 x = 1 while x * A[0] <= M: x *= a ans += p_cnt + 1 answer = min(ans + 1, answer) if a * (P ** p_cnt) > M: answer = min(1, answer) if answer == float("inf"): print(-1) else: print(answer) if __name__ == "__main__": main()